1. 说明

下文的案例是根据上一篇文章进行的修改。因此请优先读取上一章博文内容《Saltstack_使用指南11_配置管理-状态之间依赖关系

2. 主机规划

salt 版本

 [root@salt100 ~]# salt --version
salt 2018.3. (Oxygen)
[root@salt100 ~]# salt-minion --version
salt-minion 2018.3. (Oxygen)

salt jinja 文档

https://docs.saltstack.com/en/latest/topics/jinja/index.html

Jinja2 文档

 http://docs.jinkan.org/docs/jinja2/
http://docs.jinkan.org/docs/jinja2/templates.html

注意事项

修改了master或者minion的配置文件,那么必须重启对应的服务。

3. jinja 用法

 # 注意有空格
这里有两种分隔符: {% ... %} 和 {{ ... }} 。前者用于执行诸如 for 循环 或赋值的语句,后者把表达式的结果打印到模板上。
{# ... #} 为注释语法

jinja 在 状态中的使用

 3步走:
、告诉File模块,你要使用jinja
- template: jinja
、列出参数列表
- defaults:
HttpPort:
、模板引用
{{ HttpPort }} 模板里面支持:salt 远程执行、grains 和 pillar 进行赋值

4. 案例

对上一章案例内容进行改造。

添加 jinja 信息。

添加了 jinja 的好处:

1、  可以把 mariadb.sls 也规整到 init.sls;

2、  这样就是一个 SLS 文件对外,而不是多个 SLS;

3、  在执行 SLS 的时候,直接整体/分批执行,而不是选定某个或某些 minion 执行;不需要指定 minion 目标,减少人为出错的可能性;

4、  后期维护方便

4.1. 部署架构

4.2. 本章涉及的 pillar 的信息

可参见:《Saltstack_使用指南05_数据系统-Pillar

 [root@salt100 pillar]# pwd
/srv/pillar
[root@salt100 pillar]# cat top.sls
base:
'*':
- web_pillar.service_appoint # 下面的跟本章节无关,可以不管
# 使用通配符
'salt0*':
- web_pillar.apache
- web_pillar.user # 引用
# 指定具体minion
'salt03':
- web_pillar.apache
- web_pillar.user # 引用
[root@salt100 pillar]# cat web_pillar/service_appoint.sls # pillar 的 SLS
{% if (grains['ip4_interfaces']['eth0'][] == '172.16.1.11' and grains['host'] == 'salt01')
or (grains['ip4_interfaces']['eth0'][] == '172.16.1.12' and grains['host'] == 'salt02')
or (grains['ip4_interfaces']['eth0'][] == '172.16.1.13' and grains['host'] == 'salt03')
%}
# 注释信息 需要顶格书写
service_appoint: www
{% elif grains['ip4_interfaces']['eth0'][] == '172.16.1.100' %}
service_appoint: mariadb
{% endif %}

使 pillar 生效

 [root@salt100 pillar]# salt '*' saltutil.refresh_pillar  # 刷新
[root@salt100 pillar]# salt '*' pillar.item service_appoint # 查看 pillar 中 service_appoint 的信息
salt03:
----------
service_appoint:
www
salt02:
----------
service_appoint:
www
salt100:
----------
service_appoint:
mariadb
salt01:
----------
service_appoint:
www

4.3. 配置文件 httpd.conf 修改

 [root@salt100 file]# pwd
/srv/salt/lamp2/file
[root@salt100 file]# vim httpd.conf
# Listen
# 下面的是本次修改的部分 ★★★★★
Listen {{ HttpPort }}
………………
# If your host doesn't have a registered DNS name, enter its IP address here.
#
#ServerName www.example.com:
# 下面的是本次修改的部分 ★★★★★
# 格式 ServerName 本机内网IP:Port
# 这样的话,在 apache.sls 文件中就不用写规则获取 minion的内网IP了,
# 因为在状态执行的时候,就会根据下文的 grains 规则得到对应 minion 的内网IP
# ServerName {{ grains['ip4_interfaces']['eth0'][] }}:{{ HttpPort }} # 这里是一个变量,如此的话,在 apache.sls 中需要写规则获取 minion 的内网IP
# 优先这种写法,后期改变时,直接改 sls 文件即可。而不用改变该配置文件
ServerName {{ LocalInnerIP }}:{{ HttpPort }} # 「#」 注释,只是针对 httpd 服务,对于 jinja 仍然是可用的 ★★★★★
# salt 模块 支持
# hw_addr_eth0={{ HwAddr_eth0 }}
# grains 支持
# ip6_interfaces_eth0={{ IP6_Interface_eth0 }}
# pillar 支持
# pillar_user={{ Pillar_User }}

4.4. apache.sls 文件修改

 [root@salt100 lamp2]# pwd
/srv/salt/lamp2
[root@salt100 lamp2]# ll
total
-rw-r--r-- root root Jan : apache.sls
drwxr-xr-x root root Jan : file
-rw-r--r-- root root Jan : init.sls
-rw-r--r-- root root Dec : mariadb.sls
-rw-r--r-- root root Dec : php.sls
[root@salt100 lamp2]# cat apache.sls
apache-service:
pkg.installed:
- name: httpd file.managed:
- name: /etc/httpd/conf/httpd.conf
- source: salt://lamp2/file/httpd.conf
- user: root
- gourp: root
- mode:
- backup: minion
- require: # 我依赖谁
- pkg: apache-service # 依赖 apache-service 中 pkg 的安装包
# 新加 jinja 内容 # 本次修改内容 ★★★★★
- template: jinja
- defaults:
LocalInnerIP: {{ grains['ip4_interfaces']['eth0'][] }}
HttpPort:
# salt远程执行模块 支持 ★★★★★
HwAddr_eth0: {{ salt['network.hw_addr'] ('eth0') }} # 注意 ] ( 之间的空格
# grains 支持 【其实 defaults 下的第一行就是,这里在重复一遍】
IP6_Interface_eth0: {{ grains['ip6_interfaces']['eth0'][] }}
# pillar 支持
Pillar_User: {{ pillar['level1']['level2']['my_user'] }} service.running:
- name: httpd
- enable: True
- reload: True
- require: # 我依赖谁
- pkg: apache-service
- watch: # 我监控谁
# 一旦发生变化,就重加载服务
- file: apache-service # 监控 apache-service 中 file 的文件

4.5. init.sls 文件修改

 [root@salt100 lamp2]# pwd
/srv/salt/lamp2
[root@salt100 lamp2]# ll
total
-rw-r--r-- root root Jan : apache.sls
drwxr-xr-x root root Jan : file
-rw-r--r-- root root Jan : init.sls
-rw-r--r-- root root Dec : mariadb.sls
-rw-r--r-- root root Dec : php.sls
[root@salt100 lamp2]# cat init.sls # 根据 pillar 来区分,哪些 minion 执行哪些 SLS 文件
include: # 我包含谁
{% if pillar['service_appoint'] == 'www' %}
- lamp2.apache
- lamp2.php
{% elif pillar['service_appoint'] == 'mariadb' %}
- lamp2.mariadb
{% endif %}

4.6. 执行 SLS

 # 测试一下,看是否可执行,有没有什么异常
[root@salt100 lamp2]# salt 'salt01' state.sls lamp2.init test=True
# 根据 init.sls 信息,选取覆盖 if 条件中所有情况的 minion 并测试一下,看是否正常
[root@salt100 lamp2]# salt -L 'salt01,salt100' state.sls lamp2.init test=True
# 单个执行,并查看返回情况
# 这时可在 salt01 机器,通过 ps -ef | grep 'httpd' 和 netstat -lntup | grep 'httpd' 查看
# 可见 httpd 已经重加载,并且端口从 改为了
[root@salt100 lamp2]# salt 'salt01' state.sls lamp2.init
[root@salt100 lamp2]# salt '*' state.sls lamp2.init # 批量执行,并查看返回情况

4.7. 部分截图

[root@salt100 lamp2]# salt 'salt01' state.sls lamp2.init test=True  # 对应的截图

对应 salt 远程执行、grains、pillar 的情况

 [root@salt100 ~]# salt 'salt01' network.hw_addr eth0
salt01:
:0c:::1b:7a
[root@salt100 ~]# salt 'salt01' grains.item ip6_interfaces:eth0
salt01:
----------
ip6_interfaces:eth0:
- fe80::20c:29ff:fe95:1b7a
[root@salt100 ~]# salt 'salt01' pillar.item level1:level2:my_user
salt01:
----------
level1:level2:my_user:
lisi

Saltstack_使用指南12_配置管理-jinja模板的更多相关文章

  1. SaltStack配置管理-jinja模板

    上一篇:SaltStack配置管理-状态间关系 需求:需要apache配置文件里面监听的端口是每个minion本地的地址 saltstack默认的模板是jinjia模板 参考文档:http://doc ...

  2. Saltstack_使用指南03_配置管理

    1. 主机规划 注意事项 修改了master或者minion的配置文件,那么必须重启对应的服务. 2. 了解YAML 具体地址 https://docs.saltstack.com/en/latest ...

  3. Saltstack_使用指南11_配置管理-状态之间依赖关系

    1. 说明 下文的案例是根据上一篇文章进行的修改.因此请优先读取上一篇文章内容<Saltstack_10_配置管理-状态模块> 并且目录进行了变化,从 /srv/salt/lamp 变为了 ...

  4. Saltstack_使用指南10_配置管理-状态模块

    1. 主机规划 salt 版本 [root@salt100 ~]# salt --version salt (Oxygen) [root@salt100 ~]# salt-minion --versi ...

  5. 5 LAMP配置管理:模块(state、file、pkg、service)、jinja模板、job管理、redis主从

    1. 配置管理:state和file https://docs.saltstack.com/en/latest/topics/states/index.html Full list of states ...

  6. Saltstack_使用指南17_salt-ssh

    1. 主机规划 salt 版本 [root@salt100 ~]# salt --version salt (Oxygen) [root@salt100 ~]# salt-minion --versi ...

  7. 架构师成长之路5.6-Saltstack配置管理(jinja模板)

    点击架构师成长之路 架构师成长之路5.6-Saltstack配置管理(jinja模板) 配置管理工具: Pupper:1. 采用ruby编程语言:2. 安装环境相对较复杂:3.不支持远程执行,需要FU ...

  8. SaltStack的配置管理--jinja (七)

    SaltStack的配置管理--jinja 需求场景:使用jinja模板,让各节点的httpd都监听在本机的ip [root@7mini-node1 apache]# vim files/httpd. ...

  9. saltstack通过jinja模板,grains方式将配置的变量值写入到配置文件中?

    需求描述: 在通过saltstack进行jinja模板获取值的时候,可以通过grains的方式,获取一些操作系统相关的信息,比如,OS,ip地址等,在这里演示下,做个记录. 演示: 1.修改sls文件 ...

随机推荐

  1. 综合5项百度大脑AI技术,快速构建智能交通方案

    一.整体方案:思路:整合百度AI功能,通过百度AI解决.优化在公交运行过程中遇到的运营.管理.安全等方面的问题.具体如下: 安全方面:通过驾驶员检测+语音合成,对驾驶员状态进行实时检测,跟踪,告警.  ...

  2. oracle性能优化(项目中的一个sql优化的简单记录)

    在项目中,写的sql主要以查询为主,但是数据量一大,就会突出sql性能优化的重要性.其实在数据量2000W以内,可以考虑索引,但超过2000W了,就要考虑分库分表这些了.本文主要记录在实际项目中,一个 ...

  3. MSP430系列单片机特性及应用领域

    概述 MSP430系列单片机是德州仪器1996年开始推向市场的一种16位超低功耗的混合信号处理器,给人们留下的最大的亮点是低功耗而且速度快,汇编语言用起来很灵活,寻址方式很多,指令很少,容易上手.主要 ...

  4. weblogic的linux静默搭建

    前言: Weblogic与Tomcat都是java应用的容器,而这两者有什么大的不同呢?Tomcat是Apache基金会提供的Servlet容器,它支持JSP, Servlet和JDBC等J2EE关键 ...

  5. Java题库——Chapter15 事件驱动编程和动画

    Chapter 15 Event-Driven Programming and Animations Section 15.2 Events and Event Sources1.    A Java ...

  6. netcore 2.2 使用 Autofac 实现自动注入

    Autofac自动注入是通过名称约定来实现依赖注入 ps:本demo接口层都以“I”开头,以“Service”结尾.服务层实现都以“Service”结尾. 为什么要实现自动注入 大多时候,我们都是 以 ...

  7. Centos7通过yum跟源码编译安装Nginx

    源码编译安装 http://nginx.org/en/download.html 到官网下载,然后用XFTP上传到root目录 把文件解压出来 tar -zxvf nginx-1.16.0.tar.g ...

  8. doPost()和doGet()方法的区别?

    GET和POST请求都是http的请求方式,用户通过不同的http的请求方式完成对资源(url)的不同操作.GET,POST,PUT,DELETE就对应着对这个资源的查 ,改 ,增 ,删 4个操作,具 ...

  9. ksoap2 android 调用WebService

    webService,soap,wsdl的基本概念? 详情请看维基百科 基于soap 1.1, soap 1.2 的请求和响应数据源 查找了很久都是基于json格式传输数据,但是最终还是找到了基于xm ...

  10. Java程序远程无法执行nohup命令

    问题的上下文: 由于生产无法使用 jenkins 发布,所以采用 ch.ethz.ssh2 或叫 ganymed-ssh2 的开源 java 的 ssh api 进行远程发布. 在发起重启时,远程执行 ...