Ansible中的任务执行控制

  • Post author:
  • Post category:其他


一、实验环境的配置

真机和三台虚拟机,真机作为ansible主机,其他作为被控主机

在真机中给br0配置两个ip,一个为内部网段

给虚拟机进行网络配置,配置ip为172.25.5网段的10,20,30

给真机下载并安装epel源,安装ansible


新建用户并设定密码


创建密钥

给root加密

使用root身份给被控主机添加devops用户和设定密码,使用openssl passwd -6生成密码的加密字符

给devops进行加密

给被控主机进行权力下放

二、循环

1、简单循环

loop:        ##赋值列表

– value1

– value2

– …

{

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

2、循环散列或字典列表

三、条件

#多条条件组合#

when:

– 条件1

– 条件2
when:

条件1 and 条件2

– 条件1

– 条件2
when:

条件1 or 条件2
when: >

条件1

or

条件2

#条件判断#

=            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列表中


练习:

建立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

使用ansible-doc -l可以查看模块的使用方式

可以查看ansible_facts的相关路径

四、触发器

notify:        触发器当

遇到更改时触发

handlers

handlers:    触发器

触发后执行

的动作

练习: ansible-playbook httpd.yml -e ‘port=8080’可以修改端口

五、处理失败任务

1.ignore_errors

#作用:

当play遇到任务失败是会终止

ignore_errors: yes    将会忽略任务失败使下面的任务继续运行

2.force_handlers

#作用:

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

3.changed_when

#作用:

#控制任务在何时报告它已进行更改

4.failed_when

#当符合条件时强制任务失败

5.block

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上



版权声明:本文为WHDCCDJA原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。