ansible系列(28)--ansible的playbook异常处理
1. playbook的异常处理
1.1 Playbook错误忽略
在 playbook 执行的过程中,难免会遇到一些错误(返回结果不为0)。由于 playbook 遇到错误后,不会执行之后的任务,不便于调试,此时,可以使用 ignore_errors 来暂时忽略错误,使得 playbook 继续执行。
首先编写一个
playbook文件:[root@xuzhichao playbook]# cat ignore.yml
- hosts: localhost
tasks:
- name: Igonre False
shell: /bin/false <==此命令返回值一定不为0 - name: Print Message
debug:
msg: "It's hard to here"
此时运行
playbook时会在Igonre False任务中报错,无法继续向下运行:[root@xuzhichao playbook]# ansible-playbook ignore.yml PLAY [localhost] ********************************************************************************************************************************************** TASK [Igonre False] *******************************************************************************************************************************************
fatal: [localhost]: FAILED! => {"changed": true, "cmd": "/bin/false", "delta": "0:00:00.024018", "end": "2021-08-05 21:36:36.638534", "msg": "non-zero return code", "rc": 1, "start": "2021-08-05 21:36:36.614516", "stderr": "", "stderr_lines": [], "stdout": "", "stdout_lines": []} PLAY RECAP ****************************************************************************************************************************************************
localhost : ok=0 changed=0 unreachable=0 failed=1 skipped=0 rescued=0 ignored=0
修改
playbook文件,忽略中间task的错误,继续向下执行:[root@xuzhichao playbook]# cat ignore.yml
- hosts: localhost
tasks:
- name: Igonre False
shell: /bin/false
ignore_errors: yes - name: Print Message
debug:
msg: "It's hard to here"
此时运行
playbook会忽略掉中间task的错误,继续向下运行:[root@xuzhichao playbook]# ansible-playbook ignore.yml PLAY [localhost] ********************************************************************************************************************************************** TASK [Igonre False] *******************************************************************************************************************************************
fatal: [localhost]: FAILED! => {"changed": true, "cmd": "/bin/false", "delta": "0:00:00.004268", "end": "2021-08-05 21:37:16.630140", "msg": "non-zero return code", "rc": 1, "start": "2021-08-05 21:37:16.625872", "stderr": "", "stderr_lines": [], "stdout": "", "stdout_lines": []}
...ignoring <==忽略错误 TASK [Print Message] ******************************************************************************************************************************************
ok: [localhost] => {
"msg": "It's hard to here"
} PLAY RECAP ****************************************************************************************************************************************************
localhost : ok=2 changed=1 unreachable=0 failed=0 skipped=0 rescued=0 ignored=1
也可以写成下面的形式来保证
task的返回值为0:- hosts: localhost
tasks:
- name: Igonre False
shell: /bin/false || /bin/ture - name: Print Message
debug:
msg: "It's hard to here"
1.2 task执行失败强制调用handlers
通常情况下,当 task 失败后, playbook 将会终止,任何在前面已经被 tasks notify 的 handlers 都不会被执行。如果你在 playbook 中设置了 force_handlers: yes 参数,被通知的 handlers 就会被强制执行。
请看下面的
playbook:[root@xuzhichao playbook]# cat force_handlers.yml
- hosts: localhost tasks:
- name: Copy Configure File
template:
src: conf/nginx.conf.j2
dest: /tmp/nginx.conf
notify: Start Nginx - name: Igonre False
shell: /bin/false handlers:
- name: Start Nginx
service:
name: nginx
state: started
当
conf/nginx.conf.j2文件发生改变时,由于在Igonre False这个task中执行出现错误,将不会执行handlers中的内容。[root@xuzhichao playbook]# ansible-playbook force_handlers.yml PLAY [localhost] ********************************************************************************************************************************************** TASK [Copy Configure File] ************************************************************************************************************************************
ok: [localhost] TASK [Igonre False] *******************************************************************************************************************************************
fatal: [localhost]: FAILED! => {"changed": true, "cmd": "/bin/false", "delta": "0:00:00.006289", "end": "2021-08-05 22:09:40.799988", "msg": "non-zero return code", "rc": 1, "start": "2021-08-05 22:09:40.793699", "stderr": "", "stderr_lines": [], "stdout": "", "stdout_lines": []} PLAY RECAP ****************************************************************************************************************************************************
localhost : ok=1 changed=0 unreachable=0 failed=1 skipped=0 rescued=0 ignored=0
若此时需要强制执行
handlers中的内容,需要使用force_handlers: yes参数,playbook修改如下:[root@xuzhichao playbook]# cat force_handlers.yml
- hosts: localhost
force_handlers: yes tasks:
- name: Copy Configure File
template:
src: conf/nginx.conf.j2
dest: /tmp/nginx.conf
notify: Start Nginx - name: Igonre False
shell: /bin/false handlers:
- name: Start Nginx
service:
name: nginx
state: started
此时运行
playbook,当conf/nginx.conf.j2文件发生改变时,handlers将会被强制执行:[root@xuzhichao playbook]# ansible-playbook force_handlers.yml PLAY [localhost] ********************************************************************************************************************************************** TASK [Copy Configure File] ************************************************************************************************************************************
changed: [localhost] TASK [Igonre False] *******************************************************************************************************************************************
fatal: [localhost]: FAILED! => {"changed": true, "cmd": "/bin/false", "delta": "0:00:00.003843", "end": "2021-08-05 22:12:00.335807", "msg": "non-zero return code", "rc": 1, "start": "2021-08-05 22:12:00.331964", "stderr": "", "stderr_lines": [], "stdout": "", "stdout_lines": []} RUNNING HANDLER [Start Nginx] *********************************************************************************************************************************
ok: [localhost] PLAY RECAP ****************************************************************************************************************************************************
localhost : ok=2 changed=1 unreachable=0 failed=1 skipped=0 rescued=0 ignored=0
1.3 控制Tasks报告状态为OK
有时一些task会在每次playbook运行是都会执行一次,这样会导致playbook的运行结果中该task会显示为changed状态,但是有时这些task并没有改变被控端的状态,仅仅是获取了某些信息,此时可以使用changed_when: false 来抑制这个状态。
请看下面示例:
playbook文件内容如下:
[root@xuzhichao playbook]# cat status_ok.yml
- hosts: localhost
tasks:
- name: Get Nginx Server Port
shell: netstat -ntlp | grep nginx
register: nginx_port - name: Print Nginx Port
debug:
msg:
- "{{ nginx_port.stdout_lines }}"
每次的执行结果“Get Nginx Server Port”任务状态都是changed:
[root@xuzhichao playbook]# ansible-playbook status_ok.yml PLAY [localhost] ********************************************************************************************************************************************** TASK [Get Nginx Server Port] **********************************************************************************************************************************
changed: [localhost] <==状态为changed TASK [Print Nginx Port] ***************************************************************************************************************************************
ok: [localhost] => {
"msg": [
[
"tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 26579/nginx: master "
]
]
} PLAY RECAP ****************************************************************************************************************************************************
localhost : ok=2 changed=1 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
可以使用changed_when: false 来抑制这个状态,playbook修改如下:
[root@xuzhichao playbook]# cat status_ok.yml
- hosts: localhost
tasks:
- name: Get Nginx Server Port
shell: netstat -ntlp | grep nginx
register: nginx_port
changed_when: false <==该task不再发生changed提示 - name: Print Nginx Port
debug:
msg:
- "{{ nginx_port.stdout_lines }}"
此时执行结果如下:
[root@xuzhichao playbook]# ansible-playbook status_ok.yml PLAY [localhost] ********************************************************************************************************************************************** TASK [Get Nginx Server Port] **********************************************************************************************************************************
ok: [localhost] <==变为OK状态 TASK [Print Nginx Port] ***************************************************************************************************************************************
ok: [localhost] => {
"msg": [
[
"tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 26579/nginx: master "
]
]
} PLAY RECAP ****************************************************************************************************************************************************
localhost : ok=2 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
1.4 changed_when检查任务结果
仍然以安装httpd为例,在每次修改完httpd的配置文件后,都需要检查配置文件的语法是否正确,如果不正确,则退出后续task,不重启httpd服务。
playbook文件优化如下:[root@xuzhichao playbook]# cat change_when.yml
---
- hosts: 192.168.20.23
remote_user: root tasks:
- name: Install Htttpd Server
yum:
name: httpd
state: present
tags:
- install_httpd
- install_apache - name: Configure Httpd Server
copy:
src: conf/httpd.conf.j2
dest: /etc/httpd/conf/httpd.conf
owner: "root"
group: "root"
mode: "0644"
notify: Restart Httpd Server
tags: conf_httpd - name: Check Httpd Configuer <==检测配置文件语法
shell: /usr/sbin/httpd -t
register: httpd_check
changed_when:
- httpd_check.stdout.find('OK') <==查找变量返回的结果是否有ok,如不存在则终止该tasks
- false <==被管理主机没有发生变化状态则为OK - name: Init Httpd Server
copy:
src: file/test.html.j2
dest: /var/www/html/test.html
owner: "apache"
group: "apache"
mode: "0644"
tags: init_httpd - name: Start Httpd Server
service:
name: httpd
state: started
enabled: yes
tags: start_httpd handlers:
- name: Restart Httpd Server
service:
name: httpd
state: restarted
tags: restart httpd [root@nginx03 ~]# httpd -t
Syntax OK
playbook运行结果如下:[root@xuzhichao playbook]# ansible-playbook change_when.yml PLAY [192.168.20.23] ****************************************************************************************************************************************** TASK [Install Htttpd Server] **********************************************************************************************************************************
ok: [192.168.20.23] TASK [Configure Httpd Server] *********************************************************************************************************************************
ok: [192.168.20.23] TASK [Check Httpd Configuer] **********************************************************************************************************************************
ok: [192.168.20.23] TASK [Init Httpd Server] **************************************************************************************************************************************
ok: [192.168.20.23] TASK [Start Httpd Server] *************************************************************************************************************************************
changed: [192.168.20.23] PLAY RECAP ****************************************************************************************************************************************************
192.168.20.23 : ok=5 changed=1 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
ansible系列(28)--ansible的playbook异常处理的更多相关文章
- Ansible系列(五):playbook应用和roles自动化批量安装示例
html { font-family: sans-serif } body { margin: 0 } article,aside,details,figcaption,figure,footer,h ...
- Ansible系列(三):YAML语法和playbook写法
html { font-family: sans-serif } body { margin: 0 } article,aside,details,figcaption,figure,footer,h ...
- Ansible系列(四):playbook应用和roles自动化批量安装示例
Ansible系列文章:http://www.cnblogs.com/f-ck-need-u/p/7576137.html playbook是ansible实现批量自动化最重要的手段.在其中可以使用变 ...
- Ansible系列(二):选项和常用模块
html { font-family: sans-serif } body { margin: 0 } article,aside,details,figcaption,figure,footer,h ...
- Ansible系列(一):基本配置和使用
本文目录:1.1 安装Ansible1.2 配置Ansible 1.2.1 环境配置 1.2.2 SSH互信配置 1.2.3 简单测试1.3 inventory Ansible是一种批量.自动部署工具 ...
- Ansible系列(六):各种变量定义方式和变量引用
本文目录:1.1 ansible facts1.2 变量引用json数据的方式 1.2.1 引用json字典数据的方式 1.2.2 引用json数组数据的方式 1.2.3 引用facts数据1.3 设 ...
- Ansible系列(六):循环和条件判断
本文目录:1. 循环 1.1 with_items迭代列表 1.2 with_dict迭代字典项 1.3 with_fileglob迭代文件 1.4 with_lines迭代行 1.5 with_ne ...
- Ansible系列(七):执行过程分析、异步模式和速度优化
本文目录:1.1 ansible执行过程分析1.2 ansible并发和异步1.3 ansible的-t选项妙用1.4 优化ansible速度 1.4.1 设置ansible开启ssh长连接 1.4. ...
- ansible学习笔记三:playbook和roles
参考博客: Ansible 系列之 Playbooks 剧本 -飞走不可(博客园) linux运维学习之ansible的playbook及roles的使用 - 51CTO博客 nginx 基于uwsg ...
- Ansible系列(五):各种变量定义方式和变量引用
Ansible系列文章:http://www.cnblogs.com/f-ck-need-u/p/7576137.html 1.1 ansible facts facts组件是用来收集被管理节点信息的 ...
随机推荐
- 【转载】Vue路由 hash与history 的区别
[转载]Vue路由 hash与history 的区别 两种路由模式原因 对于 Vue 这类渐进式前端开发框架, 为了构建 SPA(单页面应用), 需要引入前端路由系统, 这也就是 Vue-Router ...
- 4. Orthogonality
4.1 Orthogonal Vectors and Suspaces Orthogonal vectors have \(v^Tw=0\),and \(||v||^2 + ||w||^2 = ||v ...
- openGauss 列存表PSort索引
openGauss 列存表 PSort 索引 概述 PSort(Partial sort) Index 是在列存表的列上建的聚簇索引.CUDesc 上有每个 CU 的 min 和 max 值,但如果业 ...
- 【4】Spring框架的起源
在我们的<Java Spring框架入门教程>中对 Spring 框架进行了十分详尽的介绍和剖析,但在学习 Spring Boot 之前,在这里回顾一下 Spring 是怎么出现的. Sp ...
- redis 简单整理——内存的管理[二十六]
前言 redis 是一个内存型数据库,那么就需要重点关注一下内存了. 正文 理解Redis内存,首先需要掌握Redis内存消耗在哪些方面.有些内存消 耗是必不可少的,而有些可以通过参数调整和合理使用来 ...
- Redis 的并发竞争问题是什么?如何解决这个问题?了解 redis 事务的 CAS 方案吗?
面试官心理分析 这个也是线上非常常见的一个问题,就是多客户端同时并发写一个 key,可能本来应该先到的数据后到了,导致数据版本错了:或者是多客户端同时获取一个 key,修改值之后再写回去,只要顺序错了 ...
- numpy函数向量化,np.vectorize
import numpy as np import time def myfunc(a, b): if a>b: return a-b else: return a+b vfunc = np.v ...
- OS如何保持对计算机的控制权?
前面我们提到:OS希望在保持控制权的同时,为用户提供高性能的并发. 那么OS究竟是如何保持对计算机的控制权呢?这似乎是一个令人迷惑(但很重要!)的问题:OS也是进程,自然也需要计算资源.那既然我们希望 ...
- Advanced .Net Debugging 7:托管堆与垃圾收集
一.简介 这是我的<Advanced .Net Debugging>这个系列的第七篇文章.这篇文章的内容是原书的第二部分的[调试实战]的第五章,这一章主要讲的是从根本上认识托管堆和垃圾回收 ...
- 力扣32(java)-最长有效括号(困难)
题目: 给你一个只包含 '(' 和 ')' 的字符串,找出最长有效(格式正确且连续)括号子串的长度. 示例 1: 输入:s = "(()"输出:2解释:最长有效括号子串是 &quo ...