1. SaltStack数据系统

Grains (谷物)

Pillar (支柱)

2.Grains

Grains存放着Salt命令启动时收集的信息,运行时不收集

2.1  信息查询

收集资产

网卡,ip,cpu ....

(1)收集系统底层的msg

[root@linux-node1 ~]# salt '*' grains.ls
[root@linux-node1 ~]# salt '*' grains.items

(2)查询单个

[root@linux-node1 ~]# salt '*' grains.item fqdn
[root@linux-node1 ~]# salt '*' grains.get fqdn
[root@linux-node1 ~]# salt '*' grains.get ip4_interfaces

2.2 匹配minion

在所有centos上执行,

所有开机的虚拟机上执行

[root@linux-node1 ~]# salt -G 'os:CentOS' cmd.run 'uptime'
[root@linux-node1 ~]# salt -G 'init:systemd' cmd.run 'uptime'

2.3 top.sls中匹配minion

[root@linux-node1 ~]# vim /srv/salt/base/top.sls

2.4 配合模板来做判断

在pillar中使用

2.5 如何配置?

1.Minion配置文件中的grains (不推荐了)

(1)修改配置文件

vim /etc/minion

systemctl restart salt-minion

(2)在所有角色是memcache上执行

(3)grians配置文件

新建 grins

:后面必须有空格

(4)重启服务minion

[root@host-192-168-23-39 master]# systemctl restart salt-minion

[root@host-192-168-23-39 master]# systemctl status salt-minion

(5)执行命令

2.自定制grains

# vim grains文件

[root@linux-node1 ~]# vim /etc/salt/grains
test-grains: linux-node2 [root@linux-node1 ~]# salt '*' grains.get test-grains
linux-node2.example.com:
linux-node1.example.com:

# 重启或者重新获取grains

[root@linux-node1 ~]# systemctl restart salt-minion

# 执行命令

[root@linux-node1 ~]# salt '*' grains.get test-grains
linux-node2.example.com:
linux-node1.example.com:
linux-node2

3.Pillar

官方文档:https://docs.saltstack.com/en/latest/topics/pillar/index.html

github中pillar的配置: https://github.com/saltstack-formulas?utf8=✓&q=&type=&language=

3.1 Grains与pillar对比

Grains的问题

:静态数据,要刷新
.用户名密码,不太安全

Pillar好处

敏感data,比如配置文件设定密码

处理变量差异性

给minion指定它想要的数据
   安全性比较好,给谁指定谁能看到,其他的看不到
   安全,只有指定的人才能看到key-value 在master端设定
不用每次重启服务

pillar解析后是个python的字典

直接在salt中 写python的语法

3.2 打开默认pillar

# 默认关闭的

[root@linux-node1 ~]# salt '*' grains.get test-grains
linux-node1.example.com:
----------
linux-node2.example.com:
----------

# 配置master文件

[root@linux-node1 ~]# vim /etc/salt/master

# 重启master服务

[root@linux-node1 ~]# systemctl restart salt-master

# 执行命令

3.3 配置pillar

1.配置master文件,创建目录

[root@linux-node1 ~]# vim /etc/salt/master

[root@linux-node1 ~]# mkdir -p /srv/pillar/{base,prod}
[root@linux-node1 ~]# tree /srv/pillar/
/srv/pillar/
├── base
└── prod directories, files

[root@linux-node1 ~]# systemctl restart salt-master

2. vim apache.sls

[root@linux-node1 ~]# vim /srv/pillar/base/apache.sls
{% if grains['os'] == 'CentOS' %}
apache: httpd
{% elif grains['os'] == 'Debian'%}
apache: apache2
{% endif %}

apache: 空格注意空格

[root@linux-node1 pillar]# tree
.
├── base
│ └── apache.sls
└── prod directories, file

3. 指定哪个minion可以看到

[root@linux-node1 pillar]# vim /srv/pillar/base/top.sls

[root@linux-node1 pillar]# salt '*' pillar.items

3.4 pillar在状态文件中如何引用的

[root@linux-node1 base]# vim /srv/salt/base/web/apache.sls

执行命令

4.总结与展望

1. Grains与Pillar对比

2. 报错:Pillar报错

报错信息:apache: 空格注意空格

3.配置中心

https://www.infoq.cn/article/basis-frameworkto-implement-micro-service/

2. SaltStack数据系统: Grains、Pillar的更多相关文章

  1. SaltStack 数据系统 Grains Pillar

    grains 先来一个很好用的命令 # salt '*' grains.items \\基本上输出了所有你想要的信息 192.168.100.138: ---------- SSDs: biosrel ...

  2. Saltstack数据系统Grains和Pillar(三)

    Saltstack数据系统 分为Grains和Pillar 一.Grains 静态数据,当Minion启动的时候收集的MInion本地的相关信息.(包含操作系统版本.内核版本.CPU.内存.硬盘.设备 ...

  3. SaltStack数据系统-Grains

    上一篇:SaltStack配置管理 granis:谷粒 pillar:柱子 grains是salt的一个组件,存放minion启动时候收集的信息(状态信息) 查看 salt '*' grains.it ...

  4. SaltStack数据系统-Pillar

    上一篇:SaltStack数据系统-Grains 使用saltstack进行配置管理可以使用pillar定义主机假如是Openstack修改了一下nova的密码就需要修改很多配置文件 pillar很安 ...

  5. Saltstack_使用指南04_数据系统-Grains

    1. 主机规划 Grains文档 https://docs.saltstack.com/en/latest/topics/grains/index.html 注意事项 修改了master或者minio ...

  6. SaltStack数据系统之Grains、Pillar

    SaltStack数据系统之Grains.Pillar 1.什么是Grains? Grains是saltstack的组件,用于收集salt-minion在启动时候的信息,又称为静态信息.Grains是 ...

  7. 【02】Saltstack:Grains and Pillar

    写在前面的话 上一节谈及了 Saltstack 的安装和初始化配置,本节将谈谈 Saltstack 中两个重要的东西,Grains 和 Pillar. 数据系统 Grains 入门 Grains 是静 ...

  8. 死磕salt系列-salt grains pillar 配置

    grains 和 pillar 对比: Grains:存放静态数据,主要存储客户端的主机信息,重启grains会刷新. Pillar: 处理敏感数据, 处理差异性的文件. Grains数据系统 sal ...

  9. SaltStack入门篇(三)之数据系统Grains、Pillar

    1.什么是Grains? Grains是saltstack的组件,用于收集salt-minion在启动时候的信息,又称为静态信息.可以理解为Grains记录着每台Minion的一些常用属性,比如CPU ...

随机推荐

  1. 【0.4】mysql版本特性(5.6-8.0)【转】

    转自:http://blog.itpub.net/15498/viewspace-2650661/ MySQL 5.6 1).支持GTID复制 2).支持无损复制 3).支持延迟复制 4).支持基于库 ...

  2. 在Ubuntu上安装hadoop-2.7.7

    1.安装open-vm-tools sudo apt-get install open-vm-tools 2.安装openjdk sudo apt-get install openjdk-8-jdk ...

  3. PAT B1018.锤子剪刀布(20)

    一个没有通过,不知道为何 #include <cstdio> int change(char c) { if(c == 'B') return 0; if(c == 'C') return ...

  4. Feign的雪崩处理

    在声明式远程服务调用Feign中,实现服务灾难性雪崩效应处理也是通过Hystrix实现的.而feign启动器spring-cloud-starter-feign中是包含Hystrix相关依赖的.如果只 ...

  5. 怎样使 html 文本文字不能被选中?

    -webkit-user-select:none; -moz-user-select:none; -ms-user-select:none; user-select:none;

  6. C语言写郑州大学校友通讯录

    #include <stdio.h> #include <string.h> #include <stdlib.h> #define LEN sizeof(stru ...

  7. PMP - 控制图(质量控制工具)

    这里用一个具体例子来解释什么是控制图. 假设现在工厂需要生成直径为1000mm (允许偏差为振幅4个标准差,即:±4mm)的螺丝钉.我们要如何保证生成过程的质量呢? 这时候我们应该对生成出来的产品进行 ...

  8. JXOI 2018滚粗记

    --Update5.2 成绩出了,见后文 听说省选VAN写游记是传统,本蒟蒻也来发一篇吧. DAY 0 本来以为省选不在JKFZ举行的结果又是在JKFZ,本校作战感觉终究会是好一些吧,和jyh一起向教 ...

  9. VS2008提示无法打开包括文件:“afxcontrolbars.h”解决办法

    主要造成这个问题的主要原因是,在打了SP1的VS2008下创建的项目放在没有打SP1的VS2008下就会报错   解决办法: 一.给VS2008打上SP1补丁即可      此方法比较彻底,但是安装较 ...

  10. 设计模式及UML图

    UML图 1. 依赖关系