内容简介:所属分类:ansible
- A+
所属分类:ansible 运维技术
在本博客中,ansible是一个系列文章,我们会尽量以通俗易懂的方式总结ansible的相关知识点。
ansible系列博文直达链接:ansible轻松入门系列
"ansible系列"中的每篇文章都建立在前文的基础之上,所以, 请按照顺序阅读这些文章,否则有可能在阅读中遇到障碍。
在写这篇文章时,遇到了一个小bug,经过测试,当前最新版本(2.6.2)的ansible不存在此bug,于是将ansible版本从2.4.2升级到了2.6.2,从这篇文章开始,如果没有特殊说明,演示环境中的ansible的版本为2.6.2.
在 linux 中,我们可以使用test命令进行一些常用的判断操作,比如,使用test命令判断"/testdir"是否存在,示例如下
# test -e /testdir # echo $? 0
上述命令表示判断"/testdir"是否存在于系统中,如果"/testdir"存在,则返回true,如果"/testdir"不存在,则返回false,而在linux中,命令的返回值为0表示true,返回值为非0表示false,上例的返回值为0,所以"/testdir"存在于文件系统中,我们也可以在 shell 脚本中使用test命令进行判断,示例如下
#!/bin/bash if test -e /testdir; then echo "testdir exist" fi
其实,在ansible中,也有类似的用法,只不过ansible没有使用linux的test命令,而是使用了jinja2的tests,借助tests,我们可以进行一些判断操作,tests会将判断后的布尔值返回,如果条件成立,则返回true,如果条件不成立,tests会返回false,我们通常会在条件判断时使用到tests,那么怎样在ansible中使用jinja2的tests进行判断呢?我们先来看一个小例子,示例如下:
--- - hosts: test70 remote_user: root gather_facts: no vars: testpath: /testdir tasks: - debug: msg: "file exist" when: testpath is exists
如上例所示,我们定义了一个testpath变量,这个变量的值是"/testdir"路径,我通过when判断"/testdir"路径是否存在,没错,就是这么简单,"is exists"中的"exists"就是tests的一种,它与"test -e"命令的作用是相同的,通过"exists"可以判断ansible主机中的对应路径是否存在(注意:是ansible控制主机中的路径,与目标主机没有关系),当对应的路径存在于ansible控制节点时,"is exists"为真,是不是很简单?
"is exists"可以在路径存在时返回真,但是有时,我们想要在路径不存在时返回真,我们该怎么办呢?我们可以使用"is not exists","is not exists"表示对应路径不存在时返回真,示例如下:
vars: testpath: /testdir1 tasks: - debug: msg: "file not exist" when: testpath is not exists
你一定已经明白了,在ansible中,"is exists"表示如果路径存在于ansible节点则返回真,"is not exists"表示如果路径不存在于ansible节点则返回真,当我们使用一种tests进行条件判断时,在tests前面加上"is"进行判断,也可以在tests前面加上"is not"进行取反的判断,当然,在前一篇文章中,我们已经总结了取反的逻辑操作符,所以,我们也可以对整个条件取反,比如如下示例
vars: testpath: /testdir1 tasks: - debug: msg: "file not exist" when: not testpath is exists
上例取反的效果与"is not"的效果相同。
在ansible中,除了能够使用"exists"这种tests,还有一些别的tests能够使用,我们来认识一下这些tests
判断变量的一些tests
defined :判断变量是否已经定义,已经定义则返回真
undefind :判断变量是否已经定义,未定义则返回真
none :判断变量值是否为空,如果变量已经定义,但是变量值为空,则返回真
上述tests的使用示例如下:
--- - hosts: test70 remote_user: root gather_facts: no vars: testvar: "test" testvar1: tasks: - debug: msg: "Variable is defined" when: testvar is defined - debug: msg: "Variable is undefined" when: testvar2 is undefined - debug: msg: "The variable is defined, but there is no value" when: testvar1 is none
当对应的条件为真时,你可以看到debug模块对应的输出。
判断执行结果的一些tests
success 或 succeeded:通过任务的返回信息判断任务的执行状态,任务执行成功则返回真
failure 或 failed:通过任务的返回信息判断任务的执行状态,任务执行失败则返回真
change 或 changed:通过任务的返回信息判断任务的执行状态,任务执行状态为changed则返回真
skip 或 skipped:通过任务的返回信息判断任务的执行状态,当任务没有满足条件,而被跳过执行时,则返回真
上述tests的使用示例如下:
--- - hosts: test70 remote_user: root gather_facts: no vars: doshell: "yes" tasks: - shell: "cat /testdir/abc" when: doshell == "yes" register: returnmsg ignore_errors: true - debug: msg: "success" when: returnmsg is success - debug: msg: "failed" when: returnmsg is failure - debug: msg: "changed" when: returnmsg is change - debug: msg: "skip" when: returnmsg is skip
如上例所示,我们调用了shell模块,将shell模块的返回信息注册在了returnmsg变量中,之后的debug任务均通过returnmsg变量判断shell模块的执行状态,因为shell模块有可能执行失败,所以,我们为shell模块添加了"ignore_errors: true",以便即使shell模块执行失败,也能执行后面的任务,并且,我为shell模块添加了判断条件,当不满足条件时,shell模块则会跳过,即不会执行,你可以修改一下条件,以便测试skip的判断效果。
判断路径的一些tests
注:如下tests的判断均针对于ansible主机中的路径,与目标主机无关
file : 判断路径是否是一个文件,如果路径是一个文件则返回真
directory :判断路径是否是一个目录,如果路径是一个目录则返回真
link :判断路径是否是一个软链接,如果路径是一个软链接则返回真
mount:判断路径是否是一个挂载点,如果路径是一个挂载点则返回真
exists:判断路径是否存在,如果路径存在则返回真
注:上述test名均为2.6版本中的名称,在2.5版本之前某些test需要加上"is_"前缀
上述tests的使用示例如下:
--- - hosts: test70 remote_user: root gather_facts: no vars: testpath1: "/testdir/test" testpath2: "/testdir/" testpath3: "/testdir/testsoftlink" testpath4: "/testdir/testhardlink" testpath5: "/boot" tasks: - debug: msg: "file" when: testpath1 is file - debug: msg: "directory" when: testpath2 is directory - debug: msg: "link" when: testpath3 is link - debug: msg: "link" when: testpath4 is link - debug: msg: "mount" when: testpath5 is mount - debug: msg: "exists" when: testpath1 is exists
判断字符串的一些tests
lower:判断包含字母的字符串中的字母是否是纯小写,字符串中的字母全部为小写则返回真
upper:判断包含字母的字符串中的字母是否是纯大写,字符串中的字母全部为大写则返回真
上述tests的使用示例如下:
--- - hosts: test70 remote_user: root gather_facts: no vars: str1: "abc" str2: "ABC" tasks: - debug: msg: "This string is all lowercase" when: str1 is lower - debug: msg: "This string is all uppercase" when: str2 is upper
判断整除的一些tests
even :判断数值是否是偶数,是偶数则返回真
odd :判断数值是否是奇数,是奇数则返回真
divisibleby(num) :判断是否可以整除指定的数值,如果除以指定的值以后余数为0,则返回真
上述tests的使用示例如下:
--- - hosts: test70 remote_user: root gather_facts: no vars: num1: 4 num2: 7 num3: 64 tasks: - debug: msg: "An even number" when: num1 is even - debug: msg: "An odd number" when: num2 is odd - debug: msg: "Can be divided exactly by" when: num3 is divisibleby(8)
其他的一些testst
version:可以用于对比两个版本号的大小,或者与指定的版本号进行对比,使用语法为 version('版本号', '比较操作符')
注:2.5版本中此tests从version_compare更名为version
示例如下
--- - hosts: test70 remote_user: root vars: ver: 7.4.1708 ver1: 7.4.1707 tasks: - debug: msg: "This message can be displayed when the ver is greater than ver1" when: ver is version(ver1,">") - debug: msg: "system version {{ansible_distribution_version}} greater than 7.3" when: ansible_distribution_version is version("7.3","gt")
上例中有两个task
第一个task中,当ver的版本号大于ver1时,返回真,条件成立,debug模块输出"This message can be displayed when the ver is greater than ver1"
第二个task中,当facts中的ansible_distribution_version的值大于7.3时,返回真,条件成立,debug模块输出对应信息
细心如你一定发现了,">"与"gt"都表示"大于",当使用version时,支持多种风格的比较操作符,你可以根据自己的使用习惯进行选择,version支持的比较操作符如下
大于:>, gt
大于等于:>=, ge
小于:<, lt
小于等于:<=, le
等于: ==, =, eq
不等于:!=, <>, ne
subset:判断一个list是不是另一个list的子集,是另一个list的子集时返回真
superset : 判断一个list是不是另一个list的父集,是另一个list的父集时返回真
注:2.5版本中上述两个tests从issubset和issuperset更名为subset和superset
示例如下
--- - hosts: test70 remote_user: root gather_facts: no vars: a: - 2 - 5 b: [1,2,3,4,5] tasks: - debug: msg: "A is a subset of B" when: a is subset(b) - debug: msg: "B is the parent set of A" when: b is superset(a)
string:判断对象是否是一个字符串,是字符串则返回真
--- - hosts: test70 remote_user: root gather_facts: no vars: testvar1: 1 testvar2: "1" testvar3: a tasks: - debug: msg: "This variable is a string" when: testvar1 is string - debug: msg: "This variable is a string" when: testvar2 is string - debug: msg: "This variable is a string" when: testvar3 is string
上例playbook中只有testvar2和testvar3会被判断成字符串,testvar1不会
number:判断对象是否是一个数字,是数字则返回真
示例如下
--- - hosts: test70 remote_user: root gather_facts: no vars: testvar1: 1 testvar2: "1" testvar3: 00.20 tasks: - debug: msg: "This variable is number" when: testvar1 is number - debug: msg: "This variable is a number" when: testvar2 is number - debug: msg: "This variable is a number" when: testvar3 is number
上例playbook中只有testvar1和testvar3会被判断成数字,testvar2不会
这篇文章就总结到这里,希望能够对你有所帮助~
我的微信公众号
关注"实用运维笔记"微信公众号,当博客中有新文章时,可第一时间得知哦~
以上所述就是小编给大家介绍的《ansible笔记(27):条件判断与tests》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- ansible笔记(26):条件判断
- python3 第六章 - 条件判断
- ansible笔记(29):条件判断与错误处理
- ansible笔记(28):条件判断与block
- 一文详解Python字符串条件判断方法
- vue+node全栈移动商城【9】注册页面判断条件
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
jQuery 技术内幕
高云 / 机械工业出版社 / 2014-1-1 / 99元
本书首先通过“总体架构”梳理了各个模块的分类、功能和依赖关系,让大家对jQuery的工作原理有大致的印象;进而通过“构造 jQuery 对象”章节分析了构造函数 jQuery() 的各种用法和内部构造过程;接着详细分析了底层支持模块的源码实现,包括:选择器 Sizzle、异步队列 Deferred、数据缓存 Data、队列 Queue、浏览器功能测试 Support;最后详细分析了功能模块的源码实......一起来看看 《jQuery 技术内幕》 这本书的介绍吧!