Ansible Jinja2 模板概述
一、jinja2模板概述
#什么是jinja2模板
jinja2是Python的全功能模板引擎,模
#Jinja2与Ansible啥关系
Ansible通常会使用jinja2模板来修改被管理主机的配置文件等...在saltstack中同样会使用到jinja2
如果在100台主机上安装redis,每台redis的监听地址都不一样,如何解决?
#Ansible如何使用Jinja2
使用Ansible的jinja2模板也就是使用template模块,该模块和copy模块一样,都是将文件复制到远端主机上去,但是区别在于,template模块可以获取到文件中的变量,而copy则是原封不动的把文件内容复制过去。之前我们在推送rsync的backup脚本时,想把脚本中的变量名改成主机名,如果使用copy模块则推送过去的就是{
{ ansible_fqdn }},不变,如果使用template,则会变成对应的主机名。
#Ansible使用Jinja2注意事项
Ansible允许jinja2模板中使用条件判断和循环,但是不允许在playbook中使用。
注意:不是每个管理员都需要这个特性,但是有些时候jinja2模块能大大提高效率。
二、Ansible Jinja2 模板使用
1.变量使用语法
{
{ EXPR }} 输出变量值,会输出自定义的变量值或facts
1.playbook文件使用template模块
2.模板文件里面变量使用 {
{ 名称 }},比如 {
{ PORT }} 或使用facts
2.Jinja2模板逻辑判断语法
#shell中的判断语法
[root@m01 ]# vim pd.sh
#!/bin/bash
age=$1
if [ $age -lt 18 ];then
echo "小姐姐"
else
echo "大妈"
fi
#Jinja2模板判断语法
#条件判断
{% if EXPR %}
{% elif EXPR %}
{% else %}
{% endif %}
3.Jinja2模板循环语法
#shell中的循环
[root@m01 ]# vim xh.sh
#!/bin/bash
for i in `seq 10`
do
echo $i
done
#Jinja2模板循环语法
#循环表达式
{% for i in EXPR %}
{% endfor %}
4.注释
#shell中的注释
使用 # 写在注释内容最前面
#Jinja2模板注释语法
{# COMMENT #}
三、jinja2模板测试
1.实例一
1、配置登陆文件的 jinja2 模板
[root@m01 ]# vim motd.j2
Welcome to {
{ ansible_fqdn }}
This system total mem is : {
{ ansible_memtotal_mb }} MB
This system free mem is: {
{ ansible_memfree_mb }} MB
2、编写剧本
[root@m01 ]# vim motd.yml
- hosts: all
tasks:
- name: Config motd
template:
src: ./motd.j2
dest: /etc/motd
3、执行并查看结果
[root@m01 ]# ansible-playbook motd.yml
#查看结果
Connecting to 10.0.0.51:22...
Connection established.
To escape to local shell, press 'Ctrl+Alt+]'.
Last login: Thu Dec 24 15:29:37 2020 from 10.0.0.61
Welcome to db01
This system total mem is : 972 MB
This system free mem is: 267 MB
[root@db01 ~]#
2.实例二
1、配置数据库配置文件
[root@m01 ]# vim /etc/my.cnf
innodb_buffer_pool_size = {
{ ansible_memtotal_mb * 0.8 }}M
2、编写剧本
[root@m01 ]# cat my.yml
- hosts: db01
tasks:
- name: Config Mariadb
template:
src: /etc/my.cnf
dest: /etc/
3、执行并查看
[root@m01 ]# ansible-playbook my.yml
#检查
[root@db01 ~]# vim /etc/my.cnf
[mysqld]
innodb_buffer_pool_size = 777.6M
4、jinja2模板修改
[root@m01 ]# vim /etc/my.cnf
[mysqld]
{% if ansible_memtotal_mb == 972 %}
innodb_buffer_pool_size = 800M
{% elif ansible_memtotal_mb == 1980 %}
innodb_buffer_pool_size = 1600M
{% endif %}
5、再次执行查看
#查看服务器
1.如果服务器内存是 972M,则配置为 innodb_buffer_pool_size = 800M
2.如果服务器内存是 1980M,则配置为 innodb_buffer_pool_size = 1600M
3.实例三:使用jinja2模板配置nginx负载均衡
0、先给负载均衡安装nginx
1、准备负载均衡配置文件
#1.正常的配置文件
[root@m01 ]# vim conf/upstream.conf
upstream web {
server 172.16.1.7;
server 172.16.1.8;
}
server {
listen 80;
server_name linux.wp.com;
location / {
proxy_pass http://web;
proxy_set_header Host $http_host;
}
}
#2.不正经的配置文件
[root@m01 ]# vim conf/upstream.j2
upstream {
{ server_name }} {
{% for i in range(7,20) %}
server {
{ net_ip }}.{
{ i }};
{% endfor %}
}
server {
listen {
{ web_port }};
server_name {
{ server_name }};
location / {
proxy_pass http://{
{ server_name }};
proxy_set_header Host $http_host;
}
}
2、配置变量文件
[root@m01 ]# vim upstream_vars.yml
server_name: linux.wp.com
web_port: 80
net_ip: 172.16.1
3、编写剧本
[root@m01 ]# vim lb.yml
- hosts: lb_server
vars_files: ./upstream_vars.yml
tasks:
- name: Config Nginx Upstream
template:
src: conf/upstream.j2
dest: /etc/nginx/conf.d/upstream.conf
notify: restert_upstream
- name: Start Nginx Server
systemd:
name: nginx
state: started
handlers:
- name: restert_upstream
systemd:
name: nginx
state: restarted
4、执行并测试
[root@m01 ]# ansible-playbook lb.yml
4.实例四:使用jinja2模板配置keepalived
1、准备keepalived配置文件
#1.正经的配置文件
[root@m01 ]# vim conf/keepalived.conf
global_defs {
router_id lb02
}
vrrp_instance VI_1 {
state BACKUP
interface eth0
virtual_router_id 50
priority 100
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
10.0.0.3
}
}
#2.不正经的配置文件
[root@m01 ]# vim conf/keepalived.conf
global_defs {
router_id {
{ ansible_fqdn }}
}
vrrp_instance VI_1 {
{% if ansible_fqdn == "lb01" %}
state MASTER
priority 100
{% else %}
state BACKUP
priority 90
{% endif %}
interface eth0
virtual_router_id 50
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
10.0.0.3
}
}
2、配置剧本
[root@m01 ]# cat keepalived.yml
- hosts: lb_server
tasks:
- name: Install keepalived Server
yum:
name: keepalived
state: present
- name: Config keepalived Server
template:
src: conf/keepalived.j2
dest: /etc/keepalived/keepalived.conf
- name: Start keepalived Server
systemd:
name: keepalived
state: started