内容简介:所属分类:ansible
- A+
所属分类:ansible 运维技术
在本博客中,ansible是一个系列文章,我们会尽量以通俗易懂的方式总结ansible的相关知识点。
ansible系列博文直达链接:ansible轻松入门系列
"ansible系列"中的每篇文章都建立在前文的基础之上,所以, 请按照顺序阅读这些文章,否则有可能在阅读中遇到障碍。
话接前文,我们继续来总结一些常用的过滤器。
--- - hosts: test70 remote_user: root gather_facts: no tasks: ################################################################################ #在调用 shell 模块时,如果引用某些变量时需要添加引号,则可以使用quote过滤器代替引号 #示例如下,先看示例,后面会有注解 - shell: "echo {{teststr | quote}} > /testdir/testfile" vars: teststr: "a\nb\nc" #上例中shell模块的写法与如下写法完全等效 #shell: "echo '{{teststr}}' > /testdir/testfile" #没错,如你所见,quote过滤器能够代替引号 #上例中,如果不对{{teststr}}添加引号,则会报错,因为teststr变量中包含"\n"转义符 ################################################################################ #ternary过滤器可以实现三元运算的效果 示例如下 #如下示例表示如果name变量的值是John,那么对应的值则为Mr,否则则为Ms #简便的实现类似if else对变量赋值的效果 - debug: msg: "{{ (name == 'John') | ternary('Mr','Ms') }}" vars: name: "John" ################################################################################ #basename过滤器可以获取到一个路径字符串中的文件名 - debug: msg: "{{teststr | basename}}" vars: teststr: "/testdir/ansible/testfile" ################################################################################ #获取到一个windows路径字符串中的文件名,2.0版本以后的ansible可用 - debug: msg: "{{teststr | win_basename}}" vars: teststr: 'D:\study\zsythink' ################################################################################ #dirname过滤器可以获取到一个路径字符串中的路径名 - debug: msg: "{{teststr | dirname}}" vars: teststr: "/testdir/ansible/testfile" ################################################################################ #获取到一个windows路径字符串中的文件名,2.0版本以后的ansible可用 - debug: msg: "{{teststr | win_dirname}}" vars: teststr: 'D:\study\zsythink' ################################################################################ #将一个windows路径字符串中的盘符和路径分开,2.0版本以后的ansible可用 - debug: msg: "{{teststr | win_splitdrive}}" vars: teststr: 'D:\study\zsythink' #可以配合之前总结的过滤器一起使用,比如只获取到盘符,示例如下 #msg: "{{teststr | win_splitdrive | first}}" #可以配合之前总结的过滤器一起使用,比如只获取到路径,示例如下 #msg: "{{teststr | win_splitdrive | first}}" ################################################################################ #realpath过滤器可以获取软链接文件所指向的真正文件 - debug: msg: "{{ path | realpath }}" vars: path: "/testdir/ansible/testsoft" ################################################################################ #relpath过滤器可以获取到path对于“指定路径”来说的“相对路径” - debug: msg: "{{ path | relpath('/testdir/testdir') }}" vars: path: "/testdir/ansible" ################################################################################ #splitext过滤器可以将带有文件名后缀的路径从“.后缀”部分分开 - debug: msg: "{{ path | splitext }}" vars: path: "/etc/nginx/conf.d/test.conf" #可以配置之前总结的过滤器,获取到文件后缀 #msg: "{{ path | splitext | last}}" #可以配置之前总结的过滤器,获取到文件前缀名 #msg: "{{ path | splitext | first | basename}}" ################################################################################ #to_uuid过滤器能够为对应的字符串生成uuid - debug: msg: "{{ teststr | to_uuid }}" vars: teststr: "This is a test statement" ################################################################################ #bool过滤器可以根据字符串的内容返回bool值true或者false #字符串的内容为yes、1、True、true则返回布尔值true,字符串内容为其他内容则返回false - debug: msg: "{{ teststr | bool }}" vars: teststr: "1" #当和用户交互时,有可能需要用户从两个选项中选择一个,比如是否继续, #这时,将用户输入的字符串通过bool过滤器处理后得出布尔值,从而进行判断,比如如下用法 #- debug: # msg: "output when bool is true" # when: some_string_user_input | bool ################################################################################ #map过滤器可以从列表中获取到每个元素所共有的某个属性的值,并将这些值组成一个列表 #当列表中嵌套了列表,不能越级获取属性的值,也就是说只能获取直接子元素的共有属性值。 - vars: users: - name: tom age: 18 hobby: - Skateboard - VideoGame - name: jerry age: 20 hobby: - Music debug: msg: "{{ users | map(attribute='name') | list }}" #也可以组成一个字符串,用指定的字符隔开,比如分号 #msg: "{{ users | map(attribute='name') | join(';') }}" ################################################################################ #与 python 中的用法相同,两个日期类型相减能够算出两个日期间的时间差 #下例中,我们使用to_datatime过滤器将字符串类型转换成了日期了类型,并且算出了时间差 - debug: msg: '{{ ("2016-08-14 20:00:12"| to_datetime) - ("2012-12-25 19:00:00" | to_datetime) }}' #默认情况下,to_datatime转换的字符串的格式必须是“%Y-%m-%d %H:%M:%S” #如果对应的字符串不是这种格式,则需要在to_datetime中指定与字符串相同的时间格式,才能正确的转换为时间类型 - debug: msg: '{{ ("20160814"| to_datetime("%Y%m%d")) - ("2012-12-25 19:00:00" | to_datetime) }}' #如下方法可以获取到两个日期之间一共相差多少秒 - debug: msg: '{{ ( ("20160814"| to_datetime("%Y%m%d")) - ("20121225" | to_datetime("%Y%m%d")) ).total_seconds() }}' #如下方法可以获取到两个日期“时间位”相差多少秒,注意:日期位不会纳入对比计算范围 #也就是说,下例中的2016-08-14和2012-12-25不会纳入计算范围 #只是计算20:00:12与08:30:00相差多少秒 #如果想要算出连带日期的秒数差则使用total_seconds() - debug: msg: '{{ ( ("2016-08-14 20:00:12"| to_datetime) - ("2012-12-25 08:30:00" | to_datetime) ).seconds }}' #如下方法可以获取到两个日期“日期位”相差多少天,注意:时间位不会纳入对比计算范围 - debug: msg: '{{ ( ("2016-08-14 20:00:12"| to_datetime) - ("2012-12-25 08:30:00" | to_datetime) ).days }}' ################################################################################ #使用base64编码方式对字符串进行编码 - debug: msg: "{{ 'hello' | b64encode }}" #使用base64编码方式对字符串进行解码 - debug: msg: "{{ 'aGVsbG8=' | b64decode }}" ################################################################################# #使用sha1算法对字符串进行哈希 - debug: msg: "{{ '123456' | hash('sha1') }}" #使用md5算法对字符串进行哈希 - debug: msg: "{{ '123456' | hash('md5') }}" #获取到字符串的校验和,与md5哈希值一致 - debug: msg: "{{ '123456' | checksum }}" #使用blowfish算法对字符串进行哈希,注:部分系统支持 - debug: msg: "{{ '123456' | hash('blowfish') }}" #使用sha256算法对字符串进行哈希,哈希过程中会生成随机"盐",以便无法直接对比出原值 - debug: msg: "{{ '123456' | password_hash('sha256') }}" #使用sha256算法对字符串进行哈希,并使用指定的字符串作为"盐" - debug: msg: "{{ '123456' | password_hash('sha256','mysalt') }}" #使用sha512算法对字符串进行哈希,哈希过程中会生成随机"盐",以便无法直接对比出原值 - debug: msg: "{{ '123123' | password_hash('sha512') }}" #使用sha512算法对字符串进行哈希,并使用指定的字符串作为"盐" - debug: msg: "{{ '123123' | password_hash('sha512','ebzL.U5cjaHe55KK') }}" #如下方法可以幂等的为每个主机的密码生成对应哈希串 #有了之前总结的过滤器用法作为基础,你一定已经看懂了 - debug: msg: "{{ '123123' | password_hash('sha512', 65534|random(seed=inventory_hostname)|string) }}"
这篇文章就总结到这里,快动手实践一下吧~
我的微信公众号
关注"实用运维笔记"微信公众号,当博客中有新文章时,可第一时间得知哦~
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
精通Spring
罗时飞 / 第1版 (2005年4月1日) / 2005-4 / 39.0
本书深入剖析了当前流行的轻量级开发框架Spring技术。本书总共分成3部分。第一部分,重点阐述Spring的架构。这部分内容循序渐进带领开发者进入Spring中。主要在于阐述Spring IoC和Spring AOP。第二部分,重点阐述Spring的使用。这部分内容从简化Java/J2EE的角度出发,从J2EE平台各个技术层面分析、并给出大量的研究实例,对Spring提供的API进行阐述。主要在于......一起来看看 《精通Spring》 这本书的介绍吧!