ansible条件使用

1、条件使用最简单的方式

ansible中使用条件最简单的方式如下所示:

[root@ansibleserver kel]# cat conditions.yml

---

- hosts: servers

tasks:

- name: "shutdown centos system"

command: /sbin/reboot

when: ansible_lsb.id == "CentOS"

在以上例子中,主要是根据收集的fact变量来判断哪些是centos服务器,从而将对应的centos服务器进行重启操作,执行结果如下:

[root@ansibleserver kel]# ansible-playbook -i hosts conditions.yml

SSH password:

PLAY [servers] ****************************************************************

GATHERING FACTS ***************************************************************

ok: [192.168.1.164]

ok: [192.168.1.172]

ok: [192.168.1.171]

ok: [192.168.1.163]

TASK: [shutdown centos system] ************************************************

skipping: [192.168.1.163]

skipping: [192.168.1.164]

changed: [192.168.1.172]

changed: [192.168.1.171]

PLAY RECAP ********************************************************************

192.168.1.163              : ok=1    changed=0    unreachable=0    failed=0

192.168.1.164              : ok=1    changed=0    unreachable=0    failed=0

192.168.1.171              : ok=2    changed=1    unreachable=0    failed=0

192.168.1.172              : ok=2    changed=1    unreachable=0    failed=0

在上面的结果中,只有centos的服务器进行了重启,然后其他类型的服务器跳过。

如何来进行过滤fact的变量,如下所示:

[root@ansibleserver kel]# ansible -i hosts centosservers -m setup -a "filter=ansible_lsb*"

SSH password:

192.168.1.171 | success >> {

"ansible_facts": {

"ansible_lsb": {

"codename": "Final",

"description": "CentOS release 6.4 (Final)",

"id": "CentOS",

"major_release": "6",

"release": "6.4"

}

},

"changed": false

}

192.168.1.172 | success >> {

"ansible_facts": {

"ansible_lsb": {

"codename": "Final",

"description": "CentOS release 6.4 (Final)",

"id": "CentOS",

"major_release": "6",

"release": "6.4"

}

},

"changed": false

}

在其中,可以看到引用变量的方式是使用点的方式,在上例中使用的变量为ansible_lsb,然后取id值,那么就是为ansible_lsb.id的方式。

2、条件使用的组合

在使用条件的时候,可能有很多种组合来进行判断,从而可以使用如下的方式来使用:

[root@ansibleserver kel]# cat conditions.yml

---

- hosts: servers

tasks:

- name: "shutdown centos system"

command: /sbin/reboot

when: (ansible_lsb.id == "CentOS" and ansible_lsb.release == "6.4") or

(ansible_lsb.id == "RedHat" and ansible_lsb.release == "6.4")

在使用when条件语句的时候,可以使用的符号为and,or,然后用括号来包含进去

3、根据结果判断使用执行下一步

- command: /bin/ls

register: result

ignore_errors: True

- command: ifconfig

when: result|failed

- command: /bin/ls

when: result|success

- command: /bin/ls -l

when: result|skipped

此例子中主要是根据使用的条件来进行判断执行下一步的命令,在官方手册上执行成功为succeded,在实际进行测试的时候未success,从而在第一句执行的时候,根据变量result得到相关的结果,从而执行下一步的选择。

4、根据布尔变量来判断执行步骤

在设定一个布尔变量之后,可以根据布尔变量来进行判断下一步执行的步骤,如下所示:

[root@ansibleserver kel]# cat conditions1.yml

---

- hosts: servers

vars:

epic: True

tasks:

- shell: echo "this is epic"

when: epic

- shell: echo "this is not epic"

when: not epic

在这里设置了布尔变量epic,然后根据布尔变量值,来使用哪些步骤执行,哪些步骤不进行执行

5、根据变量是否定义判断执行步骤

当定义了变量的时候执行一个步骤,当未定义变量的时候执行另外一个步骤,如下所示:

---

- hosts: servers

vars:

epic: epic

tasks:

- shell: echo "this is defined {{epic}}"

when: epic is defined

- shell: echo "this is not defined "

when: kel is undefined

6、在每个循环中进行判断定义

---

- hosts: servers

tasks:

- name: do somethings

command: echo {{item}}

with_items: [0,2,4,6,8]

when: item > 5

在使用这种方式的时候,在每个循环中会进行判断,如上例子所示,对items的02468这个集合进行判断,当item的值大于5的时候才会执行这个command

7、在roles中使用条件语句

---

- hosts: servers

tasks:

roles:

- {role: templatecontrol,when ansible_lsb_id == 'CentOS'}

在roles中使用的时候,注意符号的使用,在上面中,使用的单独的role,然后用花括号进行包含起来,然后在role中是用逗号进行条件判断

8、条件导入

[root@ansibleserver kel]# ls -l RedHat.yml os.default.yml CentOS.yml

-rw-r--r-- 1 root root 12 Feb  1 15:42 CentOS.yml

-rw-r--r-- 1 root root 12 Feb  1 15:43 os.default.yml

-rw-r--r-- 1 root root 12 Feb  1 15:42 RedHat.yml

[root@ansibleserver kel]# cat conditions1.yml

---

- hosts: servers

vars_files:

- ["{{ansible_lsb.id}}.yml","os.default.yml"]

tasks:

- name: do somethings

command: echo {{kel}}

[root@ansibleserver kel]# cat CentOS.yml

kel: centos

[root@ansibleserver kel]# cat RedHat.yml

kel: redhat

[root@ansibleserver kel]# cat os.default.yml

kel: defalt

在这个里面,根据条件来导入变量的文件,根据fact作为变量,然后来决定使用哪个变量,从而进行导入变量使用

ansible条件使用--实践的更多相关文章

  1. ansible playbook最佳实践

    本篇主要是根据官方翻译而来,从而使简单的翻译,并没有相关的实验步骤,以后文章会补充为实验步骤,此篇主要是相关理论的说明,可以称之为中文手册之一,具体内容如下: Ansible playbooks最佳实 ...

  2. ansible 学习与实践

    title: ansible 学习与实践 date: 2016-05-06 16:17:28 tags: --- ansible 学习与实践 一 介绍 ansible是新出现的运维工具是基于Pytho ...

  3. Ansible条件测试

    本节内容: Ansible条件测试 一.Ansible条件测试 在ansible中还可以进行条件测试.如果需要根据变量.facts或此前任务的执行结果来做为某task执行与否的前提时要用到条件测试. ...

  4. Tidb 离线Ansible方式部署实践

    1.最近浏览到一个比较新的分布式数据库Tidb,开源看起来比较牛的样子,一时手痒就动手试试部署 2.参考官方 Ansible 离线方式部署 :https://pingcap.com/docs-cn/o ...

  5. 011.Ansible条件语句

    一 简介 在有的时候play的结果依赖于变量.fact或者是前一个任务的执行结果,或者有的时候,我们会基于上一个task执行返回的结果而决定如何执行后续的task.这个时候就需要用到条件判断. 条件语 ...

  6. Ansible入门与实践

    一.ansible介绍 Ansible是一个简单的自动化运维管理工具,基于Python语言实现,由Paramiko和PyYAML两个关键模块构建,可用于自动化部署应用.配置.编排task(持续交付.无 ...

  7. ansible管理windows实践

    一.前言 近期打算搞搞自动部署,因为是windows服务器,一些工具和系统支持都不是太好.最后发现ansible比较火,最重要的是他支持windows.本文主要就ansible 在windows使用环 ...

  8. 自动化运维工具Ansible之LNMP实践环境部署

    Ansible-实战指南-LNMP环境部署,并使用zabbix监控 主机规划 系统初始化:必要的系统初始化 基础组件包括:zabbix监控,mariadb(用于存放zabbix监控信息) 业务组件包括 ...

  9. Ansible playbook循环实践总结<一>

    1.标准Loops 标准loops可以直接减少task的次数,如下: [root@zero01 playbook]# vi loops.yaml --- - hosts: all gather_fac ...

随机推荐

  1. scala函数式编程

    1.作为值的函数 在Scala中,函数和数字一样,可以在变量中存放函数.可以把函数赋值给一个变量,格式为:val foee=fun _(函数名+空格+_)形式 2.匿名函数 在scala中,不需要给每 ...

  2. linux c 生成uuid

    /********方法一**********/#include <stdio.h> #include <stdlib.h> #include <string.h> ...

  3. JavaScript —— attachEvent 方法的使用

    动态地给一个对象添加事件(方法). 直接上代码: <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" ...

  4. Newtonsoft.Json高级用法 1.忽略某些属性 2.默认值的处理 3.空值的处理 4.支持非公共成员 5.日期处理 6.自定义序列化的字段名称

    手机端应用讲究速度快,体验好.刚好手头上的一个项目服务端接口有性能问题,需要进行优化.在接口多次修改中,实体添加了很多字段用于中间计算或者存储,然后最终用Newtonsoft.Json进行序列化返回数 ...

  5. What a version number means

    http://stackoverflow.com/questions/3768261/best-practices-guidance-for-maintaining-assembly-version- ...

  6. C#中的转换

    11.3  转换 到目前为止,在需要把一种类型转换为另一种类型时,使用的都是类型转换.而这并不是唯一的方式. 在计算过程中,int可以采用相同的方式隐式转换为long或double,还可以定义所创建的 ...

  7. 《OD学hive》第六周20160731

    一.hive的压缩 1. hadoop的压缩 1)为什么需要压缩 MapReduce的性能瓶颈:网络IO.磁盘IO 数据量:对于MapReduce的优化,最主要.根本就是要能够减少数据量 Combin ...

  8. shell进行mysql统计

    array=(江苏 浙江 新疆 宁夏 广东 福建 重庆 江西 吉林 湖南 山东 云南  上海 河北 黑龙江 北京 四川 河南 山西 湖北 辽宁 安徽 陕西 广西 贵州 内蒙古 天津 甘肃 海南 青海 ...

  9. STL笔记(3) copy()之绝版应用

    STL笔记(3) copy()之绝版应用 我选用了一个稍稍复杂一点的例子,它的大致功能是:从标准输入设备(一般是键盘)读入一些整型数据,然后对它们进行排序,最终将结果输出到标准输出设备(一般是显示器屏 ...

  10. 修改Eclipse格式化代默认长度

    eclipse 默认设置的换行长度为80, 格式化代码后,同一个方法里面参数也经常被,换行,非常难看 1.Java代码打开Eclipse的Window菜单,然后 Preferences->Jav ...