Ansible第五章:ansible中的任务执行控制

1.循环

循环迭代任务

1.1 简单循环

loop:		##赋值列表
  - value1
  - value2
  - ...

{{item}}	##迭代变量名称

2.条件

when:
  - 条件1
  - 条件2

 2.1 条件判断

==            value == "字符串",value == 数字
<            value <  数字
>            value >  数字
<=            value <= 数字
>=            value >= 数字 
!=            value != 数字
is defined value    value is defined        变量存在
is not defined        value is not defined    变量不存在
in                  value is in value       变量为    
not in              value is not in value   变量不为
bool变量 为true        value      value的值为true
bool变量 false        not value value的值为false

value in value2        value的值在value2列表中
 

实验1:

判断文件是否存在

 

实验2:

检测硬盘是否存在

 

 脚本:

过程: 

 

检测: 

 

实验3:

in

 

2.2 多条条件组合

条件1 and 条件2

when:
  - 条件1
  - 条件2

 条件1 or 条件2

when: >
  条件1
  or
  条件2

 

实验3:

建立playbook ~/ansibles/lvm.yml要求如下:
*建立大小为1500M名为exam_lvm的lvm 在westos组中
*如果westos不存在请输出:
vg westos is not exist
*如果westos大小不足1500M请输出:
vg westos is less then 1500M
并建立800M大小的lvm
 

 

 

 

 

3.触发器

notify:触发器当遇到更改时触发handlers

handlers: 触发器触发后执行的动作

实验:
下载软件httpd,然后启动服务,火墙添加服务,如果软件已经下载,不执行启动服务和火墙

 

 服务第一次安装

服务已经安装之后:不启动 

 

4.处理失败任务

4.1 ignore_errors

作用:
当play遇到任务失败是会终止
ignore_errors: yes 将会忽略任务失败使下面的任务继续运行

实例

- name: test
  dnf:
    name: westos
    state: latest
  ignore_errors: yes
  
- name: create file
  file:
    path: /mnt/westos
    state: touch

 

4.2.force_handlers

作用:
#当任务失败后play被终止也会调用触发器进程
#example

 

---
- name: apache change port
  hosts: 172.25.0.254
  force_handlers: yes
  vars:
    http_port: 80
  tasks:
    - name: configure apache conf file
      lineinfile:
        path: /etc/httpd/conf/httpd.conf
        regexp: "^Listen"
        line: "Listen {{ http_port }}"
      notify: restart apache

    - name: install error
      dnf:
        name: westos
        state: latest

  handlers:
    - name: restart apache
      service:
        name: httpd
        state: restarted
        enabled: yes

.3.changed_when

作用:
控制任务在任何时候都更改changed (true/false)

name: apache change port
hosts: 172.25.0.254
force_handlers: yes
vars:
http_port: 8080
tasks:

name: configure apache conf file
lineinfile:
path: /etc/httpd/conf/httpd.conf
regexp: “^Listen”
line: “Listen {{ http_port }}”
changed_when: true
notify: restart apache
handlers:

name: restart apache
service:
name: httpd
state: restarted
enabled: yes
4.4.failed_when
不管命令执行成功失败,都指定输出信息(true/false)

---
- name: test
  hosts: 172.25.0.254
  tasks:
    - name: shell
      shell: echo hello
      register: westos
      failed_when: "'hello' in westos.stdout"

 4.5.block/rescue/always

block: 		##定义要运行的任务
rescue:		##定义当block句子中出现失败任务后运行的任务
always:	##定义最终独立运行的任务

 

 

#测试练习#
建立playbook ~/westos.yml要求如下:
建立大小为1500M名为/dev/vdb1的设备
如果/dev/vdb不存在请输入:
/dev/vdb is not exist
如果/dev/vdb大小不足2G请输出:
/dev/vdb is less then 2G
并建立800M大小的/dev/vdb1
此设备挂载到/westos上

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值