1
rochek 2019-02-25 12:30:47 +08:00
调用一个进程,如果你去 wait 的话会有返回值的,看着个返回值就可以。
|
2
d0m2o08 2019-02-25 12:37:15 +08:00
[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 2019-02-25 12:38:08 +08:00
ansible 剧本是可以判断返回值的
|
4
xiangyuecn 2019-02-25 12:45:28 +08:00 1
像分布式事物,复杂的一比。就算只涉及到两台机器。没接触过,搞不来,搞不好就陷入无限循环。
需要判断 成功 的 成功 是否真的 成功 (然后 成功 的 成功 真的成功 不存在!) |
5
ns2250225 OP @xiangyuecn 😂,所以来求助呀
|
6
ns2250225 OP @d0m2o08 感谢回复啊,可是如果返回失败,回滚的时候,又要重新推配置过去,然后又要重新检查,如果失败有会进入循环,就像#4 所说的那样,😭
|
7
d0m2o08 2019-02-25 13:15:11 +08:00 1
@ns2250225 哈哈我没注意审题,我原来搞过用 git 更新配置文件,本地写个 shell 拉下来之后 reload,失败通过 git 回滚再 reload, 批量的肯定所有机器环境都是一样的,有某个机器失败了肯定是这个环境和其它机器不一样,再单独处理它
|
8
owenliang 2019-02-25 13:20:49 +08:00
需要把推送任务自身作为一个持久化的记录保存起来,这样才能在异常情况下重新发现&check。
|
9
real3cho 2019-02-25 14:25:01 +08:00
薛定谔的推送
|
11
lincanbin 2019-02-25 22:38:21 +08:00
公司以前有个老同事也在用 Ansible,我记得他一个习惯就是 Ansible 跑三遍。
|