一、jinja2简介

1、jinja2模板

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

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

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

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

  • 演示实例:

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

二、构建jinja2模板

1、jinja2模板构成

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

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

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

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

  • 演示实例:

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

三、部署jinja2模板

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

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

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

  • 演示实例:

    [root@localhost ~]# cat /opt/myplay.j2
    <VirtualHost {{ ansible_facts['default_ipv4']['address'] }}:80>
    DocumentRoot /var/www/html/{{ dir_name }}
    </VirtualHost> [root@localhost ~]# cat /opt/playbook.yaml
    ---
    - hosts: all
    gather_facts: no
    tasks:
    - name: gat template
    template:
    src: /opt/myplay.j2
    dest: /tmp/myplay

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

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

四、管理模板文件

1、使用ansible_managed管理模板文件

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

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

  • 演示实例:

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

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

  • 演示实例:

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

五、控制结构

1、使用for循环

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

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

      //先在playbook中定义users变量
    [root@localhost ~]# cat /opt/playbook.yaml
    ---
    - hosts: all
    gather_facts: no
    vars:
    users:
    - zhangsan
    - lisi
    - wangwu
    tasks:
    - name: gat template
    template:
    src: /opt/myplay.j2
    dest: /tmp/myplay //查看jinja2模板文件
    [root@localhost ~]# cat /opt/myplay.j2
    {% for user in users %}
    {{ user }}
    {% endfor %}

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

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

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

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

2、使用条件句

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

  • 演示实例一:

     //现在playbook中定义user变量
    [root@localhost opt]# cat /opt/playbook.yaml
    ---
    - hosts: all
    gather_facts: no
    vars:
    user:
    - zhangsan
    - lisi
    - wangwu
    tasks:
    - name: gat template
    template:
    src: /opt/myplay.j2
    dest: /tmp/myplay //查看jinja2模板文件
    [root@localhost opt]# cat /opt/myplay.j2
    {% if True %}
    {{ user }}
    {% endif %} //执行play后,在受管主机上查看
    [root@localhost tmp]# cat myplay
    ['zhangsan', 'lisi', 'wangwu']
  • 演示实例二:

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

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

3、变量和过滤器

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

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

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

     //查看jinja2模板文件
    [root@localhost opt]# cat /opt/myplay.j2
    {{ ansible_facts['default_ipv4'] | to_json }} //查看playbook
    [root@localhost opt]# cat /opt/playbook.yaml
    ---
    - hosts: all
    gather_facts: yes
    tasks:
    - name: gat template
    template:
    src: /opt/myplay.j2
    dest: /tmp/myplay //执行play后,在受管主机上查看
    [root@localhost tmp]# cat myplay
    {"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过滤

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

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

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

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

    [root@localhost opt]# cat myplay.j2
    {{ ansible_facts['default_ipv4'] | to_nice_yaml }} //执行paly后,在受管主机上查看
    [root@localhost tmp]# cat myplay
    address: 192.168.121.81
    alias: eth0
    broadcast: 192.168.121.255
    gateway: 192.168.121.2
    interface: eth0
    macaddress: 00:0c:29:35:75:fc
    mtu: 1500
    netmask: 255.255.255.0
    network: 192.168.121.0
    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. redhat7.6 更换 centos7 YUM

    使用yum 遇到如下错误. This system is not registered to Red Hat Subscription Management. You can use subscrip ...

  2. k8s helm 安装etcd

    待续 helm install etcd bitnami/etcd \ --set statefulset.replicaCount=3 \ --set persistence.enabled=tru ...

  3. 用Taro写一个微信小程序(一)——开始一个项目

    一.Taro简介 1.名字由来 Taro['tɑ:roʊ],泰罗·奥特曼,宇宙警备队总教官,实力最强的奥特曼. 2.taro是什么 Taro 是一个开放式跨端跨框架解决方案,支持使用 React/Vu ...

  4. 判断请求是否属于Ajax请求

    我们有时候需要根据请求类型来判断返回视图名称还是JSON数据,这里记录一个判断Ajax的工具类方便日后好找 通过传入Request对象获取头信息,根据头信息判断是否属于Ajax请求 public cl ...

  5. Think5之删除单条数据功能

    //删除单条学员信息 public function deleteStu(Request $request){ $stu_id = $request->param('id'); $result ...

  6. Spring初识及其IOC入门

    一.框架 框架是一些类和接口的集合,它一个半成品,已经对基础的代码进行了封装并提供相应的API,开发者在使用框架时直接调用封装好的api可以省去很多代码编写,从而提高工作效率和开发速度. 二.Spri ...

  7. android中Stub Proxy答疑

    在上篇添加账户源码解析的博文中,我们发现功能是由AccountManager的mService成员来实现.而mService其实是AccountManagerService,如果对android系统有 ...

  8. POJ2771最大独立集元素个数

    题意:       女生和男生之间只要满足四个条件中的一个,那么两个人就不会在一起!然后给出一些男生和女生,问最多多少人一起做活动彼此不会产生暧昧关系. 思路:       这样的问题还是比较裸的问法 ...

  9. GUI简单实战——贪吃蛇

    将前面学到的GUI基础知识完成实战,完成一个简单的贪吃蛇项目 项目功能 用键盘上下左右实现贪吃蛇的自动移动 贪吃蛇吃到食物后,长度加一,分数加一 贪吃蛇吃到自己的身体,则游戏结束 按空格键实现游戏的暂 ...

  10. SpringBoot JPA + 分页 + 单元测试SpringBoot JPA条件查询

    application.properties 新增数据库链接必须的参数 spring.jpa.properties.hibernate.hbm2ddl.auto=update 表示会自动更新表结构,所 ...