本文主要是介绍5.5#Anisble中的任务执行控制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
实验环境:
1.循环
循环迭代任务
1.1 简单循环
loop: ##赋值列表- value1- value2- ...{{item}} ##迭代变量名称
实例
运行useradd.yml,依次建立三个用户westos1、westos2、westos3,密码分别为123、456、789
1.2 循环散列或字典列表
---
- name: create filehosts: 172.25.0.254tasks:- name: file moduleservice:name: "{{ item.name}}"state: "{{ item.state }}"loop:- name: httpdstate: started- name: vsftpdstate: stopped
实验:
运行useradd.yml,依次建立三个用户westos1、westos2、westos3,密码分别为123、456、789
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的值为falsevalue in value2 value的值在value2列表中
实验1:
判断文件是否存在
实验2:
检测硬盘是否存在
准备工作:
脚本:
过程:
检测:
实验3:
in
2.2 多条条件组合
条件1 and 条件2
when:- 条件1- 条件2
条件1 or 条件2
when: >条件1or条件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: testdnf:name: westosstate: latestignore_errors: yes- name: create filefile:path: /mnt/westosstate: touch
4.2.force_handlers
作用:
#当任务失败后play被终止也会调用触发器进程
#example
---
- name: apache change porthosts: 172.25.0.254force_handlers: yesvars:http_port: 80tasks:- name: configure apache conf filelineinfile:path: /etc/httpd/conf/httpd.confregexp: "^Listen"line: "Listen {{ http_port }}"notify: restart apache- name: install errordnf:name: westosstate: latesthandlers:- name: restart apacheservice:name: httpdstate: restartedenabled: yes
4.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
- name: configure apache conf file
4.4.failed_when
不管命令执行成功失败,都指定输出信息(true/false)
---
- name: testhosts: 172.25.0.254tasks:- name: shellshell: echo helloregister: westosfailed_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上
这篇关于5.5#Anisble中的任务执行控制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!