Ansible Jinja2 语法简介及使用

1、Jinja2 介绍

  • Jinja2 是基于 python 的模板引擎,功能比较类似于 PHP 的 smarty,J2ee 的 Freemarker和velocity。它能完全支持unicode,并具有集成的沙箱执行环境,应用广泛。

  • jinja2使用BSD授权

  • Jinja2的语法是由 variables(变量) 和 statement(语句) 组成,如下;

1、variables:可以输出数据

my_variables mysql_port 3307 {{ msyql_port | default('3306') }} # 默认变量

{{ some_dudes_name | capitalize }}

2、statements: 可以用来创建条件和循环等

if语句:

{% if my_conditional %}

...

{% endif %}

for 语句:

{% for item in all_items %}

`item`

......

{% endfor %}

  • jinja2 支持使用带过滤器的Unix型管道操作符,有很多的内置过滤器可供使用。

  • 我们可以用简单if和for就可以建立几乎任何的常规配置文件,不过如果你有意更进一步,jinja2 documentation (http://jinja.pocoo.org/docs/dev/)包含了很多有趣的东西可供了解。

3、jinja2 使用实例
1、引用变量
1、ansible 目录结构

root@ansible-server ansible# cd roles/template/

.

├── meta

│ └── main.yml

├── tasks

│ ├── template.yml

│ └── main.yml

├── templates

│ ├── order.j2

└── vars

└── main.yml

2、调度yml文件

root@ansible-server ansible# cat templates.yml


  • hosts: 192.168.234.102

user: root

gather_facts: false

roles:

  • role: template
  • 注意: 这里 - role: template 和 - template 是一样的
3、其他yml文件
复制代码
[root@ansible-server templates]# cat tasks/main.yml
- include: template.yml

[root@ansible-server templates]# cat tasks/template.yml
- name: create {{ PROJECT }} directory
  file: dest=/data/{{ PROJECT }} state=directory
- name: template transfor {{ PROJECT }} dir
  template: src=order.j2 dest=/data/{{ PROJECT }}/order.conf
  
[root@ansible-server templates]# cat templates/order.j2
project: {{ PROJECT }}
switch: {{ SWITCH }}
dbport: {{ DBPORT }}

[root@ansible-server templates]# cat vars/main.yml
PROJECT: "JAVA"
SWITCH: "ON"
DBPORT: "8080"

4、测试

复制代码
[root@ansible-server ansible]# ansible-playbook templates.yml --syntax-check
playbook: templates.yml

5、执行

复制代码
[root@ansible-server ansible]# ansible-playbook templates.yml 
PLAY [192.168.234.102] **************************************************************
TASK [template : include] ***************************************************
included: /etc/ansible/roles/template/tasks/template.yml for 192.168.234.102
TASK [template : create JAVA directory] *************************************
changed: [192.168.234.102]
TASK [template : template transfor java dir] ********************************
changed: [192.168.234.102]
PLAY RECAP *********************************************************************
192.168.234.102                : ok=3    changed=2    unreachable=0    failed=0  

6、查看结果

复制代码
[root@ansible-server ansible]# cat /data/JAVA/order.conf
project: JAVA
switch: ON
dbport: 8080
2、for 语句
  • 为远程主机生成服务器列表,加入该列表从192.168.234.102 web01.test.com 到192.168.234.103 web11.test.com 结束,如果手动添加就很不科学了,这里需要使用jinja2语法的for循环通过模板批量生成对应的配置文件,如下:
1、ansible 目录结构
复制代码
[root@ansible-server ansible]# cd roles/test_hosts
[root@ansible-server test_hosts]# tree
.
├── meta
│   └── main.yml
├── tasks
│   ├── file1.yml
│   └── main.yml
├── templates
│   └── test1.j2
└── vars
    └── main.yml

2、调度yml文件

复制代码
[root@ansible-server ansible]# cat test_hosts.yml
---
- hosts: 192.168.234.102
  user: root
  gather_facts: false
  roles:
   - role: test_hosts

3、各目录下 yml文件内容:

复制代码
[root@ansible-server test_hosts]# cat tasks/file1.yml 
- name: ansible jinja2 template for hosts config
  template: src=test1.j2 dest=/tmp/httpd.conf.test
  
[root@ansible-server test_hosts]# cat tasks/main.yml 
- include: file1.yml

[root@ansible-server test_hosts]# cat templates/test1.j2 
{% for id in range(201,212) %}
192.168.234.{{ id }} web{{ "%02d" | format(id-200) }}.test.com
{% endfor %}

# 解释:
{{ id }} # 提取for循环中对应的变量id值
"%02d"   # 调用的是python内置的字符串格式化输出(%d格式化整数)因为是01,02这种格式,所以是保留2位,故用02,然后将结果通过管道符 "|" 传递给format 函数做二次处理。

4、执行

root@ansible-server ansible# ansible-playbook test_hosts.yml

相关推荐
乘云数字DATABUFF2 天前
5分钟部署开源APM Databuff:OpenTelemetry全链路追踪入门实战
运维·后端
悠然南风4 天前
Ansible常见模块总结及LDAP Role 编写与调试
ansible
荣--4 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森4 天前
动手实战学 Docker — 从零到集群编排完全指南
运维
Avan_菜菜5 天前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
SelectDB6 天前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
XIAOHEZIcode7 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
用户0328472220708 天前
如何搭建本地yum源(上)
运维
大树8811 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠11 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql