目录

一、循环

二、条件

三、handlers

四、失败的处理


一、循环

使用 loop 关键字对一组项目迭代任务,循环变量 item 保存每个迭代过程中使用的值。

[student@workstation ansible]$ vim loop.yml ---
- name: Test loophosts: devgather_facts: novars:num:- one- two- three- four- fivetasks:- name: Echo someshell: "echo This is {{ item }}"loop: "{{ num }}"register: echo_results- name: Loop register vardebug:msg: "{{ item.stdout }}"loop: "{{ echo_results.results }}"

二、条件

when 语句用于有条件地运行任务。它取要测试的条件作为值。如果条件满足, 则运行任务。如果条件不满足,则跳过任务。举例,我们在 webservers 组添加了自定义事实,如果定义了那么安装一下自定义的包,否则跳过。

[student@workstation ansible]$ vim when.yml ---
- name: Install hosts: alltasks:- name: Install db_pkg if db_pkg is definedyum:name: "{{ ansible_facts.ansible_local.myfact.packages.db_pkg }}"state: presentwhen: ansible_facts.ansible_local.myfact is defined[student@workstation ansible]$ ansible-playbook when.yml
......
TASK [Install db_pkg if db_pkg is defined] *************************************************
skipping: [servera.lab.example.com]
skipping: [serverb.lab.example.com]
changed: [serverc.lab.example.com]
changed: [serverd.lab.example.com]
......

三、handlers

Ansible 模块设计为具有幂等性,playbook 及其任务可以运行多次而不会改变受管主机。
handlers 是由其他任务触发的通知的任务。仅当任务在受管主机上被更改,任务才通知handlers。
每个处理程序具有全局唯一的名称,在 playbook 中任务块的末尾触发。
处理程序可视为非活动任务,只有在使用 notify 语句调用时才会被触发。

handlers 在一个 playbook 里面和 tasks 是对齐的。

处理handlers的规范:

  • 处理程序始终按照 play 的 handlers 部分指定的顺序运行。它们不按在任务中由 notify 语句列出的顺序运行,或按任务通知它们的顺序运行。
  • 处理程序通常在相关 play 中的所有其他任务完成后运行。
  • 如果两个处理程序被错误地给予相同的名称,则仅会运行一个。
  • 即使有多个任务通知处理程序,该处理程序依然仅运行一次。如果没有任务通知处理程序,它就不会运行。

比如,覆盖 /etc/httpd/conf/httpd.conf 配置文件,使 httpd 监听端口改为 8421。这就需要修改 selinux 端口上下文、重启 httpd 服务、配置防火墙入栈规则。顺序一定是先修改 selinux 端口上下文,再重启 httpd 服务,否则因为 selinux 重启 httpd 会失败。

[student@workstation ansible]$ vim handlers.yml ---
- name: Test handlershosts: webserverstasks:- name: Httpd listen 8421copy:src: httpd.conf.newdest: /etc/httpd/conf/httpd.confnotify: - Allow Apache to listen on tcp port 8421- Restart httpd- Firewall permit 8421/tcphandlers:- name: Allow Apache to listen on tcp port 8421seport:ports: 8421proto: tcpsetype: http_port_tstate: present- name: Restart httpdservice:name: httpdstate: restarted- name: Firewall permit 8421/tcpfirewalld:port: 8421/tcpstate: enabledpermanent: yesimmediate: yes
[student@workstation ansible]$ ansible-playbook handlers.yml......
PLAY [Test handlers] ******************************************TASK [Gathering Facts] ****************************************
ok: [serverc.lab.example.com]
ok: [serverd.lab.example.com]TASK [Httpd listen 8421] **************************************
changed: [serverc.lab.example.com]
changed: [serverd.lab.example.com]RUNNING HANDLER [Allow Apache to listen on tcp port 8421] *****
changed: [serverc.lab.example.com]
changed: [serverd.lab.example.com]RUNNING HANDLER [Restart httpd] *******************************
changed: [serverd.lab.example.com]
changed: [serverc.lab.example.com]RUNNING HANDLER [Firewall permit 8421/tcp] ********************
changed: [serverd.lab.example.com]
changed: [serverc.lab.example.com]
......[student@workstation ansible]$ curl http://serverc.lab.example.com:8421
Added by ansible.
[student@workstation ansible]$ curl http://serverd.lab.example.com:8421
Added by ansible.

四、失败的处理

block-rescue-always 就类似 java 里面的 try-catch-finally 处理方式,block 升级一下,如果失败那么 rescue 一下,无论如何都有收尾工作放在 always里面。比如,webservers 组的两个服务器有 300 ~ 1000MiB 不同大小的卷组 vg_data,我们创建大小为 800MiB 的逻辑卷 lv_web,如果空间不够就创建大小 200MiB 的逻辑卷 lv_web,最后用 xfs 格式创建文件系统。

[student@workstation ansible]$ vim control.yml ---
- name: BlockRescueAlwayshosts: webserversvars:tasks:- name: Create lvmblock:- name: Check 0.8gdebug:msg: "vg_data is less than 0.8g, not enough space"when: ansible_facts.lvm.vgs.vg_data is defined and ansible_facts.lvm.vgs.vg_data.free_g | float < 0.8failed_when: ansible_facts.lvm.vgs.vg_data is defined and ansible_facts.lvm.vgs.vg_data.free_g | float < 0.8- name: Create a logical volume of 0.8glvol:vg: vg_datalv: lv_websize: 800mrescue:- name: Create a logical volume of 0.2glvol:vg: vg_datalv: lv_websize: 0.2galways:- name: Create a xfs filesystemfilesystem:fstype: xfsdev: /dev/vg_data/lv_web

执行过程

[student@workstation ansible]$ ansible-playbook control.yml PLAY [BlockRescueAlways] **********************************************************************TASK [Gathering Facts] ************************************************************************
ok: [serverd.lab.example.com]
ok: [serverc.lab.example.com]TASK [Check 0.8g] *****************************************************************************
fatal: [serverc.lab.example.com]: FAILED! => {"msg": "vg_data is less than 0.8g, not enough space"
}
skipping: [serverd.lab.example.com]TASK [Create a logical volume of 0.8g] ********************************************************
changed: [serverd.lab.example.com]TASK [Create a logical volume of 0.2g] ********************************************************
changed: [serverc.lab.example.com]TASK [Create a xfs filesystem] ****************************************************************
changed: [serverd.lab.example.com]
changed: [serverc.lab.example.com]
.......

检查结果,看到创建 lv_web 的大小是不同的。

[student@workstation ansible]$ ansible webservers -a "lvs"
serverd.lab.example.com | CHANGED | rc=0 >>LV     VG      Attr       LSize   Pool Origin Data%  Meta%  Move Log Cpy%Sync Convertroot   cl      -wi-ao---- <17.00g                                                    swap   cl      -wi-ao----   2.00g                                                    lv_web vg_data -wi-a----- 800.00m
serverc.lab.example.com | CHANGED | rc=0 >>LV     VG      Attr       LSize   Pool Origin Data%  Meta%  Move Log Cpy%Sync Convertroot   cl      -wi-ao---- <17.00g                                                    swap   cl      -wi-ao----   2.00g                                                    lv_web vg_data -wi-a----- 208.00m 

Ansible04-任务控制相关推荐

  1. 音响系统相关技术术语解释大全

    A AB 制式立体声 立体声拾音方式之一,使用灵敏度和指向性(常用心形指向性)完全相同的两只话筒,彼此相距约为 1.5 至 2 米(也可减少到 0.5 米,视声源排列宽度而定),置于声源前方拾音,然后 ...

  2. 距离传感器控制灯泡代码_如何使用颜色传感器和超声波传感器检测障碍物和避障...

    上一期的内容中,我给大家介绍了如何使用触碰传感器检测障碍物和避障,今天我们再来说说如何使用颜色传感器和超声波传感器检测障碍物和避障. 使用颜色传感器 在大多数情况下,EV3颜色传感器并不适合用于障碍物 ...

  3. 笔记本通过网线连接并控制工控机

    前言: 团队买来一个工控机,以后要安装在实验小车上使用,没有屏幕显示,于是想到用笔记本的网线接口与工控机相连,相当于把笔记本当做屏幕和键盘鼠标使用来控制工控机. 笔记本:Windows10家庭版 工控 ...

  4. 微机原理—定时计数控制接口

    别看题目很高深,其实就是很简单的定时器和计数器而已. 通常用手机定个闹钟,就是定时器的使用. 工厂里通过传送带上安装传感器,传感器传输给计算机的信号用来计数. 这是一些很简单的应用,通过很小的一个芯片 ...

  5. 【spring】编程式事务控制

    结构: AccountServiceImpl package com.itheima.service.impl;import com.itheima.dao.IAccountDao; import c ...

  6. 【Spring】spring基于注解的声明式事务控制

    结构 domin package com.itheima.domain;import java.io.Serializable;public class Account implements Seri ...

  7. 【spring】spring基于xml的声明式事务控制

    结构 domain package com.itheima.domain;import java.io.Serializable;public class Account implements Ser ...

  8. 【Spring】事务控制API

    Spring事务控制需要明确 1. JavaEE体系进行分层开发,事务处理位于业务层,Spring提供了分层设计==业务层==的事务处理解决方案. 2. Spring框架提供了一组事务控制的接口.在S ...

  9. 【Spring】基于xml实现事务控制(银行转账)

    代码结构 domain类 package com.itheima.domain;import java.io.Serializable;/*** 账户的实体类*/ public class Accou ...

  10. 【Spring】通过动态代理改进银行转账事务控制

    前情 银行转账的案例中,通过给业务层实现类中每个方法中通过事务控制方法添加事务控制,保证每个方法在执行时只有一个数据库连接,通过事务保证整个方法要成功全部成功,要失败都失败. 问题 业务层实现类添加事 ...

最新文章

  1. 2020届 AAAI Fellow名单新鲜出炉!!!深度学习三巨头终于齐聚
  2. SQL中的in与not in、exists与not exists的区别以及性能分析
  3. PHP获取IP地址以及IP地址所在位置
  4. hive 常见面试题
  5. bat遍历当前目录下的文件,批量重命名
  6. 【django】使用虚拟环境
  7. 2003白金一代NBA选秀
  8. List(Map(String, Object))转为Fastjson JSONArray
  9. 国际站html代码,国际站必须看得懂的HTML代码
  10. 周五跟大佬喝酒,顺便打了个球
  11. r语言导入ggplot2_R语言教程:数据结构+导入数据!
  12. PHP html 转换成PDF wkhtmltopdf HTML 转换成 PDF (JAVA C#都适用)
  13. 系统安装 使用VMware14安装XP系统
  14. maven详解_本地仓库+远程仓库_体现maven用途
  15. 功能设计:如何实现一个扫码上传附件的功能
  16. html thead作用,HTML thead 标签定义和用法详细介绍
  17. 操作系统实验六、死锁问题实验——单车道问题
  18. 自我介绍html模板王,小学生个人自我介绍模板10篇
  19. python基本函数的使用_python基础之函数的应用
  20. 计算机无法用u盘重装系统,电脑进不了系统怎么用u盘重装系统?

热门文章

  1. 服务器ip 计算机名,服务器计算机名称或者ip地址
  2. androidstudio jni开发_初识NDK开发(一)
  3. 微信公众号开发 微信消息回复开发 文本消息 图片消息开发
  4. 【iOS】快速集成轮播控件
  5. 我了解到的新知识之——电热水器用电安全
  6. COMP 0137 Machine Vision
  7. Confluence 6 查看空间活动
  8. Linux下des对称性加密
  9. 【Codeforces 738D】Sea Battle(贪心)
  10. 一个古老的问题HashMap与Hashtable区别