Grains
什么是Grains
- saltstack里的grains功能,讲的是,minion端的静态变量。grains是在minion启动时加载的,在运行过程中不会发生改变,所以是静态数据。grains中包含诸如运行的内核版本,操作系统等信息。在master端通过grains可以获得minion对应的变量值。
- 查看minion的全部静态变量:
salt '192.168.184.129' grains.ls
192.168.184.129:
- SSDs
- biosreleasedate
- biosversion
- cpu_flags
- cpu_model
- cpuarch
- disks
- dns
……(此处省略)
- 静态变量是成组出现的,如上只是列出了组的key,并没有列出value。如下是列出key和value:
salt '192.168.184.129' grains.items
192.168.184.129:
----------
SSDs:
biosreleasedate:
07/02/2015
biosversion:
6.00
cpu_flags:
- fpu
- vme
- de
……(此处省略)
- 此处,我们也可以指定key值:
salt '192.168.184.129' grains.item os
192.168.184.129:
----------
os:
CentOS
- 自定义grains.item
通过minion配置文件配置
## vim /etc/salt/minion
# #打开 default_include: minion.d/*.conf
#注意# 这步尝试过不进行,对grains.item添加无影响
## vim /etc/salt/minion.d/id.conf
grains:
id: 4727
user: luohaowen
## wq
/etc/init.d/salt-minion start
## master端
#执行# salt '192.168.184.129' grains.item user
192.168.184.129:
----------
user:
luohaowen
#执行# salt '192.168.184.129' grains.item id
192.168.184.129:
----------
id:
4727
通过grains模块自定义item(这样子也是写入到minion端的文件/etc/salt/grains中)
saltstack的模块就像Python中的模块(在这里更像是字典,因为他是字典格式),我们可以调用模块里的方法,对其进行操作。下面是调用grains模块的方法自定义item:
[root@localhost ~]# salt 192.168.184.129 grains.append worktype 'yunwei'
192.168.184.129:
----------
worktype:
- yunwei
[root@localhost ~]# salt 192.168.184.129 grains.item worktype
192.168.184.129:
----------
worktype:
- yunwei
[root@localhost ~]# salt 192.168.184.129 grains.setvals "{'id':'4727','department':'huoshanhu'}"
192.168.184.129:
----------
department:
huoshanhu
id:
4727
[root@localhost ~]# salt 192.168.184.129 grains.item id
192.168.184.129:
----------
id:
4727
[root@localhost ~]# salt 192.168.184.129 grains.item department
192.168.184.129:
----------
department:
huoshanhu
这样的配置会在minion主机端生成配置文件grains:
[root@localhost ~]# cat /etc/salt/grains
department: huoshanhu
id: '4727'
worktype:
- yunwei
==这里可以实验下上面两种方法,如果都定义了同一个自定义item会如何?(/etc/salt/minion.d/*.conf优先)==
通过自定义Python脚本来自定义item
mkdir /srv/salt/_grains -p && cd /srv/salt/_grains/
## vim date_time.py
#!/usr/bin/env python
## 如果不是Python3需要指定utf-8编码
from datetime import datetime
def get_server_time():
grains = {}
grains['server_time'] = datetime.now().strftime('%Y-%m-%d %H:%M:%S')
return grains
## wq
## 推送到minion端
[root@localhost ~]# salt 192.168.184.129 saltutil.sync_grains
192.168.184.129:
- grains.date_time
## master端执行
[root@localhost ~]# salt 192.168.184.129 grains.item server_time
192.168.184.129:
----------
server_time:
2017-09-19 07:53:44
- 我们可以使用-G参数,通过grains来指定主机
salt -G 'os:CentOS' test.ping
- grains配置优先级顺序为/etc/salt/minion.d/grains.conf (或/etc/salt/minion) > master端自定义grains脚本(minion端/var/cache/salt/minion/extmods/grains目录下) > Grains模块定义Grains (/etc/salt/grains)
- 在/srv/salt/_grains目录下的自定义脚本,在执行完成后,强烈建议移到一个bak目录下。使该目录下是没有文件,并且再执行一次salt '*' saltutil.sync_grains操作。使minion主机上自定义模块目录是干净的,这样做的好处是可以避免和另外两个文件有配置冲突,也避免脚本之间有重复的名字定义,造成取回的结果不对。