本帖最后由 yun 于 2019-9-11 17:16 编辑
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 | last}}"
- ######################################################################
- #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) }}"
复制代码
这篇文章就总结到这里,快动手实践一下吧~
|