EX:用 Ansible 推送一个 Nginx 的配置到三台主机,推送完之后 Reload 一下,可是怎样才可以保证三台主机都 Reload 成功,如果其中一台 Reload 失败,则通知回滚(要么全部成功,要么全部失败)。有遇到过类似情况的小伙伴吗?求指导,🎄
1
rochek Feb 25, 2019
调用一个进程,如果你去 wait 的话会有返回值的,看着个返回值就可以。
|
2
d0m2o08 Feb 25, 2019
[root@rac1 data]# nginx -s reload > /dev/null 2>&1 && echo true || echo false
false [root@rac1 data]# vim /etc/nginx/conf.d/test.conf [root@rac1 data]# nginx -s reload > /dev/null 2>&1 && echo true || echo false true 是这样么 |
3
d0m2o08 Feb 25, 2019
ansible 剧本是可以判断返回值的
|
4
xiangyuecn Feb 25, 2019 像分布式事物,复杂的一比。就算只涉及到两台机器。没接触过,搞不来,搞不好就陷入无限循环。
需要判断 成功 的 成功 是否真的 成功 (然后 成功 的 成功 真的成功 不存在!) |
5
ns2250225 OP @xiangyuecn 😂,所以来求助呀
|
6
ns2250225 OP @d0m2o08 感谢回复啊,可是如果返回失败,回滚的时候,又要重新推配置过去,然后又要重新检查,如果失败有会进入循环,就像#4 所说的那样,😭
|
7
d0m2o08 Feb 25, 2019 @ns2250225 哈哈我没注意审题,我原来搞过用 git 更新配置文件,本地写个 shell 拉下来之后 reload,失败通过 git 回滚再 reload, 批量的肯定所有机器环境都是一样的,有某个机器失败了肯定是这个环境和其它机器不一样,再单独处理它
|
8
owenliang Feb 25, 2019
需要把推送任务自身作为一个持久化的记录保存起来,这样才能在异常情况下重新发现&check。
|
9
real3cho Feb 25, 2019
薛定谔的推送
|
11
lincanbin Feb 25, 2019
公司以前有个老同事也在用 Ansible,我记得他一个习惯就是 Ansible 跑三遍。
|