首先,一个任务执行失败是肯定会遇见的事情
而这时候,就需要一个备用的计划
忽略任务失败
默认情况下 任务失败的时候play会终止
但是,我们可以通过忽略失败的任务来覆盖此行文
使用关键字 ignore_errors
举个栗子
- name: Latest version of notapkg is installed
yum:
name: notapk
state: latest
ignore_errors: yes
因为不存在notapk所以任务会执行,play会终止 但是,
在该任务中使用ignore_errors,在任务失败时也将继续在主机上执行playbook
任务失败后强制执行处理程序
使用force_handlers关键字,在任务失败的时候强制执行
---
- hosts: all
force_handlers: yes
tasks:
- name: a task which always notifies its handler
command: /bin/true
notify: restart the database
- name: a task which fails because the package doesnot exist
yum:
name: notapk
state: latest
handlers:
- name: restart the database
service:
name: mariadb
state: restarted
处理程序会在任务报告changed结果时获得通知,而在报告ok或failed时不会获得通知
指定任务失败的条件
使用关键字failed_when
data:image/s3,"s3://crabby-images/8412e/8412eeaa0f0177e30460866c83fc7516cbf6f4f8" alt=""
data:image/s3,"s3://crabby-images/9be2a/9be2ab2abafcb3481c84b6ed68c5eb0ea6d1b8a5" alt=""
处理错误
使用 rescue和always语句来处理错误
如果块中的任何任务失败,则执行rescue块中的任务
在block子句中的任务或者rescue子句中的任务运行之后 always子句中的任务将会运行
反正always的语句总会执行的
data:image/s3,"s3://crabby-images/3cf1b/3cf1b0353760c57f453ec39c1170aa7cd8ad2742" alt=""
tasks:
- name: Upgrade DB
block:
- name: Upgrade the database
shell:
cmd: /usr/local/lib/upgrade-database
rescue:
- name: revert the database upgrade
shell:
cmd: /usr/local/lib/revert-database
always:
- name: always restart the database
service:
name: mariadb
state: restarted
处理任务失败实验
data:image/s3,"s3://crabby-images/bc087/bc087bc22f8ccd9aeb3ea879668b6312bada6ba4" alt=""
1.实验开始 lab control-errors start
2.去往实验文件夹并且 创建 ansible配置文件 和一个服务器(包含服务器
servera.lab.example.com在databases组当中)
3.创建playbook
data:image/s3,"s3://crabby-images/2c96e/2c96e5cae00a7721be3e764a2e7390b74442a650" alt=""
初始状态如下
data:image/s3,"s3://crabby-images/3bc46/3bc46ce6f350cfe0838f1d6d41821d5270eb3a80" alt=""
运行playbook
data:image/s3,"s3://crabby-images/14fc8/14fc8cfe3431ba30082ca421583ba0ac322bb1a4" alt=""
此时因为不存在名为http的现有安装包,所以第一个任务失败了,因此第二个任务也没有运行
更新playbook
data:image/s3,"s3://crabby-images/28688/286885268e526c74c2e0bf71e0454c908e45746b" alt=""
再次运行playbook
data:image/s3,"s3://crabby-images/6ba99/6ba992df36cca0738b7224f227d089b5841804ab" alt=""
再次更新playbook 添加block内容
data:image/s3,"s3://crabby-images/e9375/e937548031f41dbba5d00aab5eed3bda9310d089" alt=""
data:image/s3,"s3://crabby-images/7c3fb/7c3fb14ffe752d3ec20bc1bc286cb0091e424d37" alt=""
data:image/s3,"s3://crabby-images/ac0ea/ac0eae1904a549678906b0627c72eefc6c7bddf2" alt=""
再次更新playbook 更正web_package的值 为httpd
并且再次运行
data:image/s3,"s3://crabby-images/3c04b/3c04b85de152935342595cdfbbe6bb6db4b914f8" alt=""
data:image/s3,"s3://crabby-images/b057b/b057b8a6d684ee9799211d5652206ecdb560445e" alt=""
data:image/s3,"s3://crabby-images/de29c/de29cb76b0b9ba694c84e3f6263ec32de1ee2991" alt=""
data:image/s3,"s3://crabby-images/a6419/a641904bf01643904f9a57c08ecef89347f00f7d" alt=""
data:image/s3,"s3://crabby-images/20ad4/20ad4b5a300ac965f36aa537f0daef1fb3c580b7" alt=""
如果再次运行该playbook check local time 任务将再次返回changed
data:image/s3,"s3://crabby-images/2e678/2e678927c8913b0d63ed39720ea983bf524ef0c7" alt=""
data:image/s3,"s3://crabby-images/e0742/e0742c4c35532ae796d41a1be0669ba63efbf8ca" alt=""
运行playbook
data:image/s3,"s3://crabby-images/9422a/9422ad9b4d709bae9e483bb29b5d0f5a3ab4e753" alt=""
data:image/s3,"s3://crabby-images/03c2a/03c2a58c1871a414b18611278269f53164310a17" alt=""
data:image/s3,"s3://crabby-images/7b68e/7b68eb98dd587334d76762ce854dea95d7e14dad" alt=""
执行结果
data:image/s3,"s3://crabby-images/f1372/f1372a57fb456e90c46f33e0d1e46e8e85a187bd" alt=""
data:image/s3,"s3://crabby-images/837b9/837b9fc608e7f33db27f760310c40a81bd6c5116" alt=""
完成实验 lab control-errors finish