2.1 版
在剧本中,我开始了一个过程:
- name: Start Automation Agent, and enable start on boot
service: name=mongodb-mms-automation-agent state=started enabled=yes
Run Code Online (Sandbox Code Playgroud)
从播放回顾来看,该过程似乎已成功启动。
TASK [install : Start automation agent, and enable start on boot] **************
changed: [server1]
Run Code Online (Sandbox Code Playgroud)
但是,当登录到远程主机并执行 a 时ps,该进程并未运行。检查进程日志它没有通过一些先决条件(预期)。
如何在剧本中编写任务以确认流程已成功启动?
Del*_*tik 15
failed在运行检查进程是否正在运行的命令后,您可以使用Jinja2 过滤器进行检查。
这是一个使用命令的输出systemctl status apache2来确定 Apache 是否正在运行的示例:
- name: Check if Apache is running
command: systemctl status apache2
ignore_errors: yes
changed_when: false
register: service_apache_status
- name: Report status of Apache
fail:
msg: |
Service apache2 is not running.
Output of `systemctl status apache2`:
{{ service_apache_status.stdout }}
{{ service_apache_status.stderr }}
when: service_apache_status | failed
Run Code Online (Sandbox Code Playgroud)
如果第一个任务的命令失败,第二个任务将失败并显示第一个任务失败的原因。
返回代码存储在service_apache_status.rc.
失败的示例输出:
TASK: [Check if Apache is running] ***********************
failed: [localhost] => {"changed": false, "cmd": ["systemctl", "status", "apache2"], "delta": "0:00:00.009379", "end": "2016-06-06 15:17:27.827172", "rc": 3, "start": "2016-06-06 15:17:27.817793", "stdout_lines": ["* apache2.service", " Loaded: not-found (Reason: No such file or directory)", " Active: inactive (dead)"], "warnings": []}
stdout: * apache2.service
Loaded: not-found (Reason: No such file or directory)
Active: inactive (dead)
...ignoring
TASK: [Report status of Apache] ***************************
failed: [localhost] => {"failed": true}
msg: apache2 is not running
systemctl status apache2 output:
* apache2.service
Loaded: not-found (Reason: No such file or directory)
Active: inactive (dead)
Run Code Online (Sandbox Code Playgroud)
这是使用pgrep, 检查进程是否正在运行的不同(尽管可能不太可靠)的方法:
- name: Check if Apache is running
shell: pgrep apache2
ignore_errors: yes
changed_when: false
register: service_apache_status
- name: Report status of Apache
fail:
msg: |
Service apache2 is not running.
Return code from `pgrep`:
{{ service_apache_status.rc }}
when: service_apache_status.rc != 0
Run Code Online (Sandbox Code Playgroud)
这就是我现在所做的:
- name: Confirm Automation Agent is running
command: service mongodb-mms-automation-agent status
register: agent_status
failed_when: "'NOT' in agent_status.stdout"
changed_when: False
Run Code Online (Sandbox Code Playgroud)
failed_when在 1.4 中引入。changed_when: False用于抑制更改状态。阅读更多。
| 归档时间: |
|
| 查看次数: |
68361 次 |
| 最近记录: |