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模板. 一.为什么需要引入模板: 在进行软 ...
随机推荐
- python3美化表格数据输出结果
技术背景 在前面一篇博客中我们介绍过关于python的表格数据处理方案,这其中的工作重点就是对表格类型的数据进行梳理.计算和展示,本文重点介绍展示这个方面的工作.首先我们看一个案例,定义一个数组形式的 ...
- [Azure DevOps] 如何安装并配置 Build Agent
1. 编译服务器 在 Azure Pipelines 中至少需要一个编译服务器的 Agent 才能编译代码或发布软件.Azure DevOps 本身已经提供了一个 Agent,但出于各种理由(需要特殊 ...
- (十一)VMware Harbor 配置管理
VMware Harbor 配置管理 这篇主要学习一下,项目下的配置管理. 主要功能就是修改项目的访问权限 当将访问权限改为
- Salesforce学习之路(四)利用Jenkins和Git实现Salesforce的CI/CD功能
上文提到,基于CRM的二次开发是必不可少的,但是在实际项目中CI/CD是不可忽略的一个重要部分,与传统的Java,Python项目不同,如果对Salesforce进行持续集成和持续部署呢? 结合找到的 ...
- Css预编语言以及区别
一.是什么 Css 作为一门标记性语言,语法相对简单,对使用者的要求较低,但同时也带来一些问题 需要书写大量看似没有逻辑的代码,不方便维护及扩展,不利于复用,尤其对于非前端开发工程师来讲,往往会因为缺 ...
- 数据库函数-常用的MySQL函数
1.date_sub() 时间的加减 备注:record 为datetime类型 select record_time as date, order_area as orderArea, order_ ...
- hdu2435最大流最小割
2435 There is a war 题意: 给你一个有向图,其中可以有一条边是无敌的,这条边可以是图中的边,也可以是自己任意加上去的图中没有的边,这条无敌的边不可以摧毁,让1和n无法 ...
- HDU 1430 关系映射 + 打表 .
题意是中文的不解释.(http://acm.hdu.edu.cn/showproblem.php?pid=1430) 思路: 这个题目直接BFS会超时的(我一开始超时了) ,如果 ...
- Python中的socket网络模块
目录 Socket 服务端(server.py) 客户端(client.py) socket中的一些常用方法 Socket 对象(内建)方法 Python Internet 模块 Python3 提供 ...
- Linux中的shell和bash
目录 shell shell script sh bash Dash tty .pty 和 pts 学安全的我们,经常会听到说获得某服务器的shell,就是指获得某个服务器的操作权限.我们学习linu ...