文章目录
saltstack grains
grains是在minion启动时收集到的一些信息,比如操作系统类型、网卡ip、内核版本、cpu架构等,grains的信息并不是动态的,并不会实时变更,它是在minion启动时收集到的,可以根据grains收集到的一些信息,做配置管理工作
列出指定minion端所有的grains项目名:
[root@linux01 ~]# salt 'linux02' grains.ls
列出指定minion端所有的grains项目名和对应的值:
[root@linux01 ~]# salt 'linux02' grains.items
自定义grains信息
在minion端添加配置文件:
[root@linux02 ~]# vi /etc/salt/grains
配置文件内容:
name: web
#grains项目名name,值web,注意值前面需要有个空格
重启minion服务:
[root@linux02 ~]# systemctl restart salt-minion
在master端获取该自定义项目的值:
[root@linux01 ~]# salt 'linux02' grains.item name
linux02:
----------
name:
web
针对自定义grains执行命令:
[root@linux01 ~]# salt -G name:web cmd.run 'hostname;uptime'
linux02:
linux02
14:30:53 up 21:04, 2 users, load average: 0.40, 0.26, 0.27
说明:grains的主要作用就是针对多台属性相同的机器,设置相同的自定义grains值,实现saltstack批量执行命令,例如:多台数据库机器可以定义grains值为name:db,多台redis机器可以定义grains值为name:redis,即可通过saltstack批量操作多台机器
saltstack pillar
pillar和grains相似但不一样,pillar是在master端定义的,并且是针对minion定义的一些信息,像一些比较重要的数据(密码)可以存在pillar里,还可以定义变量等
在master端编辑配置文件:
[root@linux01 ~]# vim /etc/salt/master
去掉以下配置项前面的注释:
#保持默认的第二行2个空格,第三行4个空格,否则会出错
创建配置文件目录:
[root@linux01 ~]# mkdir /srv/pillar
创建子配置文件:
[root@linux01 ~]# vi /srv/pillar/test.sls
配置文件内容:
name: db
继续创建子配置文件:
[root@linux01 ~]# vi /srv/pillar/test2.sls
配置文件内容:
name: server
创建主配置文件:
[root@linux01 ~]# vi /srv/pillar/top.sls
文件内容:
base:
'linux02':
- test
'linux01':
- test2
#指定主机名hostname绑定对应的子配置文件,需要注意格式:主机名前面2个空格,子配置文件名前面4个空格
刷新pillar:
[root@linux01 ~]# salt '*' saltutil.refresh_pillar
linux02:
True
linux01:
True
验证:
[root@linux01 ~]# salt '*' pillar.item name
linux02:
----------
name:
db
linux01:
----------
name:
server
用作salt工具的匹配对象,批量操作多台机器:
[root@linux01 ~]# salt -I name:db cmd.run 'who'
linux02:
root pts/0 Dec 26