一、jinja2简介

1、jinja2模板

1️⃣:Ansiblejinja2模板系统用于模板文件,Ansible还使用jinja2语法来引用playbook中的变量

2️⃣:变量和逻辑表达式置于标记或分隔符之间;

  • 例如,jinja2模板将{% EXPR %}用于表达式或逻辑(如循环),而{{ EXPR }}则用于向最终用户输出表达式或变量的结果

3️⃣:使用{# COMMENT #}语法括起不应出现在最终文件中的注释

  • 演示实例:

    1. [root@localhost ~]# cat myplay.j2
    2. {# This is test jinja2 #}
    3. {{ ansible_facts['default_ipv4']['address'] }}
    4. {{ ansible_facts['hostsname'] }}

二、构建jinja2模板

1、jinja2模板构成

1️⃣:jinja2模板由多个元素组成:数据、变量和表达式,在呈现jinja2模板时,这些变量和表达式被替换为对应的值

2️⃣:模板中使用的变量可以在playbookvars部分中指定,也可以将受管主机的事实用作模板中的变量

3️⃣:可以使用ansible system_hostname -i inventory_file -m setup命令来获取与受管主机相关的事实

4️⃣:注意:包含jinja2模板的文件不需要有任何特定的文件扩展名(例如.j2);但是,提供此类文件扩展名会让你更容易记住它是模板文件

  • 演示实例:

    1. [root@localhost ~]# cat myplay.j2
    2. <VirtualHost {{ ansible_facts['default_ipv4']['address'] }}:80>
    3. DocumentRoot /var/www/html/{{ dir_name }}
    4. </VirtualHost>

三、部署jinja2模板

1、使用template模块自定义模板

1️⃣:jinja2模板是功能强大的工具,可用于自定义要在受管主机上部署的配置文件

2️⃣:创建了适用于配置文件的jinja2模板后,它可以通过template模板部署到受管主机上,该模块支持将控制节点中的本地文件转移到受管主机

  • 演示实例:

    1. [root@localhost ~]# cat /opt/myplay.j2
    2. <VirtualHost {{ ansible_facts['default_ipv4']['address'] }}:80>
    3. DocumentRoot /var/www/html/{{ dir_name }}
    4. </VirtualHost>
    5.  
    6. [root@localhost ~]# cat /opt/playbook.yaml
    7. ---
    8. - hosts: all
    9. gather_facts: no
    10. tasks:
    11. - name: gat template
    12. template:
    13. src: /opt/myplay.j2
    14. dest: /tmp/myplay

3️⃣:template模块还允许指定已部署文件的所有者、组、权限和SELINUX上下文,就像file模块一样

4️⃣:也可以取用validate选项运行任意命令(如visudo -c),在将文件复制到位之前检查该文件的语法是否正确

四、管理模板文件

1、使用ansible_managed管理模板文件

1️⃣:可使用ansible_managed指令中设置的"Ansible managed"字符串来给模板文件注释

2️⃣:ansible_managed指令在ansible.cfg文件中设置

  • 演示实例:

    1. [root@localhost ~]# vim /etc/ansible/ansible.cfg
    2. ansible_managed = Ansible managed //取消该行全面的注释

3️⃣:要将ansible_managed字符串包含在jinja2模板内,请使用下列语法

  • 演示实例:

    1. [root@localhost ~]# cat /opt/myplay.j2
    2. {{ ansible_managed }} //直接引用变量即可;也可以修改ansible.cfg文件中ansible managed指定的注释信息
    3. <VirtualHost {{ ansible_facts['default_ipv4']['address'] }}:80>
    4. DocumentRoot /var/www/html/{{ dir_name }}
    5. </VirtualHost>

五、控制结构

1、使用for循环

1️⃣:jinja2使用for语句来提供循环功能

  • 演示实例一:使用变量替换变量

    1. //先在playbook中定义users变量
    2. [root@localhost ~]# cat /opt/playbook.yaml
    3. ---
    4. - hosts: all
    5. gather_facts: no
    6. vars:
    7. users:
    8. - zhangsan
    9. - lisi
    10. - wangwu
    11. tasks:
    12. - name: gat template
    13. template:
    14. src: /opt/myplay.j2
    15. dest: /tmp/myplay
    16.  
    17. //查看jinja2模板文件
    18. [root@localhost ~]# cat /opt/myplay.j2
    19. {% for user in users %}
    20. {{ user }}
    21. {% endfor %}

2️⃣:loop.index变量扩展至循环当前所处的索引号。它在循环第一次执行时值为1,每一次迭代递增1

  • 演示实例二:使用loop.index变量展示索引号

    1. [root@localhost opt]# cat myplay.j2
    2. {% for user in users %}
    3. {{ loop.index }} - {{ user }}
    4. {% endfor %}
    5.  
    6. //执行后,在受管主机上查看
    7. [root@localhost tmp]# cat myplay
    8. 1 - zhangsan
    9. 2 - lisi
    10. 3 - wangwu
  • 演示实例三:使用for语句,并添加条件判断

    1. [root@localhost opt]# cat myplay.j2
    2. {% for user in users if user != "lisi" %}
    3. {{ loop.index }} - {{ user }}
    4. {% endfor %}
    5. //这样添加判断,就排除了lisi用户
    6.  
    7. //执行play后,在受管主机上查看
    8. [root@localhost tmp]# cat myplay
    9. 1 - zhangsan
    10. 2 - wangwu

2、使用条件句

1️⃣:jinja2使用if语句来提供条件控制,如果满足某些条件,这允许用户在已部署的文件中放置一行

  • 演示实例一:

    1. //现在playbook中定义user变量
    2. [root@localhost opt]# cat /opt/playbook.yaml
    3. ---
    4. - hosts: all
    5. gather_facts: no
    6. vars:
    7. user:
    8. - zhangsan
    9. - lisi
    10. - wangwu
    11. tasks:
    12. - name: gat template
    13. template:
    14. src: /opt/myplay.j2
    15. dest: /tmp/myplay
    16.  
    17. //查看jinja2模板文件
    18. [root@localhost opt]# cat /opt/myplay.j2
    19. {% if True %}
    20. {{ user }}
    21. {% endif %}
    22.  
    23. //执行play后,在受管主机上查看
    24. [root@localhost tmp]# cat myplay
    25. ['zhangsan', 'lisi', 'wangwu']
  • 演示实例二:

    1. [root@localhost opt]# cat /opt/myplay.j2
    2. {% if 2 > 1 %}
    3. {{ user }}
    4. {% endif %}
    5.  
    6. //执行play后,在受管主机上查看
    7. [root@localhost tmp]# cat myplay
    8. ['zhangsan', 'lisi', 'wangwu']

2️⃣:注意,在Ansible模板中我们可以使用jinja2循环和条件,但不能在Ansible Playbook中使用(playbook中只能用loop和when)

3、变量和过滤器

1️⃣:jinja2提供了过滤器,更改模板表达式的输出格式(例如,输出到果JSON

2️⃣:to_json过滤器使用JSON格式化表达式输出,to_yaml过滤器则使用YAML格式化表达式输出

  • 演示实例一:使用to_json过滤

    1. //查看jinja2模板文件
    2. [root@localhost opt]# cat /opt/myplay.j2
    3. {{ ansible_facts['default_ipv4'] | to_json }}
    4.  
    5. //查看playbook
    6. [root@localhost opt]# cat /opt/playbook.yaml
    7. ---
    8. - hosts: all
    9. gather_facts: yes
    10. tasks:
    11. - name: gat template
    12. template:
    13. src: /opt/myplay.j2
    14. dest: /tmp/myplay
    15.  
    16. //执行play后,在受管主机上查看
    17. [root@localhost tmp]# cat myplay
    18. {"gateway": "192.168.121.2", "interface": "eth0", "address": "192.168.121.81", "broadcast": "192.168.121.255", "netmask": "255.255.255.0", "network": "192.168.121.0", "macaddress": "00:0c:29:35:75:fc", "mtu": 1500, "type": "ether", "alias": "eth0"} 
  • 演示实例二:使用to_yaml过滤

    1. [root@localhost opt]# cat myplay.j2
    2. {{ ansible_facts['default_ipv4'] | to_yaml }}
    3.  
    4. //执行play后,在受管主机上查看
    5. [root@localhost tmp]# cat myplay
    6. {address: 192.168.121.81, alias: eth0, broadcast: 192.168.121.255, gateway: 192.168.121.2,
    7. interface: eth0, macaddress: '00:0c:29:35:75:fc', mtu: 1500, netmask: 255.255.255.0,
    8. network: 192.168.121.0, type: ether}

3️⃣:也有其他过滤器,如to_nice_jsonto_nice_yaml过滤器,它们将表达式输出格式化为JSONYAML等人类可读格式

  • 演示实例一:使用to_nice_json过滤

    1. [root@localhost opt]# cat myplay.j2
    2. {{ ansible_facts['default_ipv4'] | to_nice_json }}
    3.  
    4. //执行play后,在受管主机上查看
    5. [root@localhost tmp]# cat myplay
    6. {
    7. "address": "192.168.121.81",
    8. "alias": "eth0",
    9. "broadcast": "192.168.121.255",
    10. "gateway": "192.168.121.2",
    11. "interface": "eth0",
    12. "macaddress": "00:0c:29:35:75:fc",
    13. "mtu": 1500,
    14. "netmask": "255.255.255.0",
    15. "network": "192.168.121.0",
    16. "type": "ether"
    17. }
  • 演示实例二:使用to_nice_yaml过滤

    1. [root@localhost opt]# cat myplay.j2
    2. {{ ansible_facts['default_ipv4'] | to_nice_yaml }}
    3.  
    4. //执行paly后,在受管主机上查看
    5. [root@localhost tmp]# cat myplay
    6. address: 192.168.121.81
    7. alias: eth0
    8. broadcast: 192.168.121.255
    9. gateway: 192.168.121.2
    10. interface: eth0
    11. macaddress: 00:0c:29:35:75:fc
    12. mtu: 1500
    13. netmask: 255.255.255.0
    14. network: 192.168.121.0
    15. type: ether

4️⃣:from_jsonfrom_yaml过滤器相应要求JSON或YAML格式的字符串,并对它们进行解析

4、变量测试

1️⃣:在Ansible Playbook中与when子句一同使用的表达式是jinja2表达式;用于测试返回值的内置Ansible测试包括failedchangedsuccessdedskipped

Ansible_使用jinja2模板部署自定义文件的更多相关文章

  1. django -使用jinja2模板引擎 自定义的过滤器

    setting.py中 TEMPLATES = [ { 'BACKEND': 'django.template.backends.jinja2.Jinja2', 'DIRS': [os.path.jo ...

  2. Flask的jinja2模板中自定义过滤器的使用

    大部分的模板引擎都是支持过滤器功能的,jinja2也不例外,它提供了丰富的内置过滤器,但是有些时候还是没办法满足我们的需求,好在jinja2支持自定义过滤器,下面是一个简单的例子. 下面的例子完成了自 ...

  3. Django---Http协议简述和原理,HTTP请求码,HTTP请求格式和响应格式(重点),Django的安装与使用,Django项目的创建和运行(cmd和pycharm两种模式),Django的基础文件配置,Web框架的本质,服务器程序和应用程序(wsgiref服务端模块,jinja2模板渲染模块)的使用

    Django---Http协议简述和原理,HTTP请求码,HTTP请求格式和响应格式(重点),Django的安装与使用,Django项目的创建和运行(cmd和pycharm两种模式),Django的基 ...

  4. Pycharm 自定义文件模板

    Pycharm 自定义文件模板 每次新建文件都有相同的代码框架,每次重复敲浪费了程序员的寿命啊 按照下面方式自定义自己的模板:

  5. 自定义Web框架与jinja2模板

    web应用与web框架 web应用 对于所有的Web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端 import socket def handle_reque ...

  6. 使用jinja2模板引擎生成html文件

    使用jinja2模板引擎生成html文件 jinja2是纯Python的模板引擎,是仿照Django模板的Python模板语言. 它速度快,被广泛使用,提供了可选的沙箱模板执行环境保证安全. 使用pi ...

  7. 烂泥:vcenter通过模板部署vm

    本文由ilanniweb提供友情赞助,首发于烂泥行天下 想要获得更多的文章,可以关注我的微信ilanniweb. 前一篇文章我们介绍了有关vcenter5.5的安装与配置,这篇文章我们再来介绍下,如何 ...

  8. flask(二)之Jinja2模板与Flask-WTF

    01-文档 官方文档:http://docs.jinkan.org/docs/jinja2/ 02-基本语义 Jinja2做构成的模板文件中,文本内容大致可以分成几个种类.比如特殊文本(不进行转义,比 ...

  9. Python框架学习之Flask中的Jinja2模板

    前面也提到过在Flask中最核心的两个组件是Werkzeug和Jinja2模板.其中Werkzeug在前一节已经详细说明了.现在这一节主要是来谈谈Jinja2模板. 一.为什么需要引入模板: 在进行软 ...

随机推荐

  1. mysql大于当前时间置顶并按升序排序,小于当前时间的置尾并按降序排序

    现在用id来代替时间这样好测试 看一下测试表数据 执行按需求规则排序的sql SELECT * FROM number_generator ORDER BY id < 16 , IF(id &l ...

  2. vuejs集成echarts的一些问题

    最近在做Beetlex的数据分析平台,在开发这个产品过程中涉及到大量的数据图表展示功能:由于产品前端使用的是vuejs开发,所以在集成echarts或多或少会碰到一些问题,在这里主要讲解一下碰到的问题 ...

  3. OGG-Oracle 集成模式抽取进程,REGISTER DATABASE都做了什么?

    一.学习目标 有同事问OGG技术问题,OGG软件,在oracle数据库中,集成模式抽取进程REGISTER DATABASE,都做了什么操作? 有什么风险? 并且提到了一个抽取进程注册,在瞬时间并发占 ...

  4. BUAA_OO_第一单元

    BUAA_OO_2020_UNIT1 一.程序结构分析 第一次作业 UML & Mertrics ​ 由于数据处理简单,第一次作业中笔者发挥了面向过程的思想,将项转换成Biginteger, ...

  5. 翻译:《实用的Python编程》09_02_Third_party

    目录 | 上一节 (9.1 包) | 下一节 (9.3 版本分发) 9.2 第三方模块 Python 拥有一个包含各种内置模块的大型库(自带电池(batteries included))(译注:&qu ...

  6. 一起来看Java设计思想之23种设计模式

    目录 怎么使用设计模式 23种设计模式 创建型模式 结构型模式 行为型模式 总结 怎么使用设计模式 为什么要使用设计模式? 编写代码,写接口.写类.写方法 用设计模式做设计的作用是什么? 指导.规定如 ...

  7. 【译】Android API 规范

    [译]Android API 规范 译者按: 修改R代码遇到Lint tool的报错,搜到了这篇文档,aosp仓库地址:Android API Guidelines. 58e9b5f Project ...

  8. Hyperledger Fabric2.3环境搭建

    采用Ubuntu系统下搭建 HyperledgerFabric2.3 环境 安装GoLang 下载golang安装包 https://studygolang.com/dl 下载完成后解压,移到/usr ...

  9. 【面试题2020-03-30】面试官:对并发熟悉吗?说说Synchronized及实现原理

    一.Synchronized的基本使用 Synchronized是Java中解决并发问题的一种最常用的方法,也是最简单的一种方法. Synchronized的作用主要有三个: 1.确保线程互斥的访问同 ...

  10. Android trap攻防思路整理

    Android trap攻防                                                                      图/文 h_one 0x01 反 ...