Ansible_使用jinja2模板部署自定义文件
一、jinja2简介
1、jinja2模板
1️⃣:Ansible将jinja2模板系统用于模板文件,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️⃣:模板中使用的变量可以在playbook的vars部分中指定,也可以将受管主机的事实用作模板中的变量
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_json和to_nice_yaml过滤器,它们将表达式输出格式化为JSON或YAML等人类可读格式
- 演示实例一:使用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_json和from_yaml过滤器相应要求JSON或YAML格式的字符串,并对它们进行解析
4、变量测试
1️⃣:在Ansible Playbook中与when子句一同使用的表达式是jinja2表达式;用于测试返回值的内置Ansible测试包括failed、changed、successded和skipped
Ansible_使用jinja2模板部署自定义文件的更多相关文章
- django -使用jinja2模板引擎    自定义的过滤器
		setting.py中 TEMPLATES = [ { 'BACKEND': 'django.template.backends.jinja2.Jinja2', 'DIRS': [os.path.jo ... 
- Flask的jinja2模板中自定义过滤器的使用
		大部分的模板引擎都是支持过滤器功能的,jinja2也不例外,它提供了丰富的内置过滤器,但是有些时候还是没办法满足我们的需求,好在jinja2支持自定义过滤器,下面是一个简单的例子. 下面的例子完成了自 ... 
- Django---Http协议简述和原理,HTTP请求码,HTTP请求格式和响应格式(重点),Django的安装与使用,Django项目的创建和运行(cmd和pycharm两种模式),Django的基础文件配置,Web框架的本质,服务器程序和应用程序(wsgiref服务端模块,jinja2模板渲染模块)的使用
		Django---Http协议简述和原理,HTTP请求码,HTTP请求格式和响应格式(重点),Django的安装与使用,Django项目的创建和运行(cmd和pycharm两种模式),Django的基 ... 
- Pycharm 自定义文件模板
		Pycharm 自定义文件模板 每次新建文件都有相同的代码框架,每次重复敲浪费了程序员的寿命啊 按照下面方式自定义自己的模板: 
- 自定义Web框架与jinja2模板
		web应用与web框架 web应用 对于所有的Web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端 import socket def handle_reque ... 
- 使用jinja2模板引擎生成html文件
		使用jinja2模板引擎生成html文件 jinja2是纯Python的模板引擎,是仿照Django模板的Python模板语言. 它速度快,被广泛使用,提供了可选的沙箱模板执行环境保证安全. 使用pi ... 
- 烂泥:vcenter通过模板部署vm
		本文由ilanniweb提供友情赞助,首发于烂泥行天下 想要获得更多的文章,可以关注我的微信ilanniweb. 前一篇文章我们介绍了有关vcenter5.5的安装与配置,这篇文章我们再来介绍下,如何 ... 
- flask(二)之Jinja2模板与Flask-WTF
		01-文档 官方文档:http://docs.jinkan.org/docs/jinja2/ 02-基本语义 Jinja2做构成的模板文件中,文本内容大致可以分成几个种类.比如特殊文本(不进行转义,比 ... 
- Python框架学习之Flask中的Jinja2模板
		前面也提到过在Flask中最核心的两个组件是Werkzeug和Jinja2模板.其中Werkzeug在前一节已经详细说明了.现在这一节主要是来谈谈Jinja2模板. 一.为什么需要引入模板: 在进行软 ... 
随机推荐
- redis的线程模型
			一.单进程模型来处理客户端的请求 Redis 基于 Reactor 模式开发了自己的网络事件处理器: 这个处理器被称为文件事件处理器(file event handler): 文件事件处理器是单线程的 ... 
- redis安装、配置、启动
			一.redis默认安装位置:/usr/local/bin redis-benchmark:性能测试工具,可以在自己本子运行,看看自己本子性能如何,服务启动起来后执行redis-check-aof:修复 ... 
- 从零玩转第三方登录之QQ登录
			从零玩转第三方登录之QQ登录 前言 在真正开始对接之前,我们先来聊一聊后台的方案设计.既然是对接第三方登录,那就免不了如何将用户信息保存.首先需要明确一点的是,用户在第三方登录成功之后, 我们能拿到的 ... 
- (Set, Map, Collections工具类)JAVA集合框架二
			Java集合框架部分细节总结二 Set 实现类:HashSet,TreeSet HashSet 基于HashCode计算元素存放位置,当计算得出哈希码相同时,会调用equals判断是否相同,相同则拒绝 ... 
- 按照自己的思路去研究Spring AOP源码【1】
			目录 一个例子 Spring AOP 原理 从@EnableAspectJAutoProxy注解入手 什么时候会创建代理对象? 方法执行时怎么实现拦截的? 总结 问题 参考 一个例子 // 定义一个切 ... 
- 一台window服务器部署多个tomcat(超简单配置)!!!
			1.首先准备好已经安装好的jdk环境,点击查看JDK安装. 2.准备好一个全新的tomcat,我这里使用的是tomcat-7.0.109.rar绿色版. 3.解压文件,并复制成三份.我这里是放在F:\ ... 
- uni-app&H5&Android混合开发一 || 最全面的uni-app离线打包Android平台教程
			前言: 为什么会写这么一个教程,因为很久之前做过一个对接银行POS我们的系统是使用的H5开发的app应用.但是假如对结果银行相关业务的小伙伴应该都清楚,银行的业务相对于其他的对接方而言安全性比较高,而 ... 
- 数据分析处理之PCA OLSR PCR PLSR(NIPALS)及其Matlab代码实现
			传统的OLS(普通最小二乘)方法无法解决样本数据的共线性(multicollinearity)问题,如果你的数据样本中每个特征变量具有共线性,那么使用基于PCA的PCR和PLSR方法对数据样本进行回归 ... 
- PHP laravel系列之Blade模版
			一.什么是Blade模版? Blade 是 Laravel 提供的一个既简单又强大的模板引擎. 和其他流行的 PHP 模板引擎不一样,Blade 并不限制你在视图中使用原生 PHP 代码.所有 Bla ... 
- 去css 冗余方法
			1.float在某种意义上而言与display:inline-block属性的作用是一模一样的, 所以类似于display:block; float:left; 就是说.float:left 可以让行 ... 
