一、Ansible jinja2 模板概述
#什么是jinja2模板
jinja2是Python的全功能模板引擎
#Jinja2与Ansible啥关系
Ansible通常会使用jinja2模板来修改被管理主机的配置文件等…在saltstack中同样会使用到jinja2
如果在100台主机上安装服务,每台服务的监听的端口都不一样,如何解决?
#Ansible如何使用Jinja2
使用Ansible的jinja2模板也就是使用template模块,该模块和copy模块一样,都是将文件复制到远端主机上去,但是区别在于,template模块可以获取到文件中的变量,而copy则是原封不动的把文件内容复制过去
#Ansible使用Jinja2注意事项
Ansible允许jinja2模板中使用条件判断和循环,但是不允许在playbook中使用。
二、Ansible jinja2 模板使用
1.变量使用语法
{{ EXPR }}输出变量值,会输出自定义的变量值或facts
1)playbook文件使用template模块
2)模板文件里面变量使用{{名称}},比如{{PORT}}或使用facts内置变量
2.判断循环语法
#循环表达式
{% for i in EXPR %}
echo
{% endfor %}
{% for i in range(1,11) %}
{% endfor %}
#条件判断
{% if EXPR %}
echo
{% elif EXPR %}
echo
{% else %}
echo
{% endif %}
#注释
{# COMMENT #}
#shell中循环
#!/bin/bash
for i in `seq 10`;do
echo $i
done
#shell中判断
#!/bin/bash
#注释
age=$1
if [ $age -lt 18 ];then
echo '小姐姐'
else
echo '大妈'
fi
3.jinja2测试
1)登陆文件测试
#1.配置登录文件j2模板
[root@m01 web]# 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.推送j2模板文件
[root@m01 web]# vim motd.yml
- hosts: all
tasks:
- name: config motd
template:
src: ./motd.j2
dest: /etc/motd
2)数据库配置文件推送
#配置数据库配置文件添加
{% if ansible_memtotal_mb == 972 %}
innodb_log_buffer_pool_size=800M
{% elif ansible_memtotal_mb == 1996 %}
innodb_log_buffer_pool_size=1600M
{% endif %}
#配置推送语法
- hosts: web_group
tasks:
- name: config mysql conf
template:
src: /root/my.cnf
dest: /tmp/my.cnf
#查看远端配置
1.如果服务器内存时972,则配置为
innodb_log_buffer_pool_size=800M
2.如果服务器内容为1996,则配置为
innodb_log_buffer_pool_size=1600M
4.使用jinja2模板配置keepalived
1)配置keepalived配置文件
#正经配置文件
global_defs {
router_id lb01
}
vrrp_instance VI_1 {
state MASTER
interface eth0
virtual_router_id 50
priority 150
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
10.0.0.3
}
}
#不正经配置文件
[root@m01 web]# vim keepalived.j2
global_defs {
router_id {{ ansible_fqdn }}
}
vrrp_instance VI_1 {
{% if ansible_fqdn == "lb01" %}
state MASTER
priority 150
{% else %}
state BACKUP
priority 100
{% endif %}
interface eth0
virtual_router_id 50
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
10.0.0.3
}
}
2)配置推送
#编写playbook
[root@m01 web]# vim keepalived.yml
- hosts: lb_group
tasks:
- name: Install Keepalived Server
yum:
name: keepalived
state: present
- name: Config keepaived Conf
template:
src: ./keepalived.j2
dest: /etc/keepalived/keepalived.conf
- name: Start Keepalived Server
systemd:
name: keepalived
state: started

