Grains是saltstack记录minion静态信息的一个组件,我们可以简单地理解为Grains里面记录着每台Minion的一些常用属性,比如CPU、内存、磁盘、网络信息等,我们可以通过grains.items查看某台Minion的所有Grains信息,Minions的Grains信息是Minions启动的时候采集汇报给Master的,在实际应用环境中我们需要根据自己的业务需求去自定义一些Grains。
定义minion有三种方式:
minion端通过配置文件定义
minion端通过模块定义
Python通过模板定义
Grains简单的命令用法
salt ‘minion1‘ sys.list_functions grains
minion1:
- grains.append
- grains.delval
- grains.filter_by
- grains.get
- grains.get_or_set_hash
- grains.has_value
- grains.item
- grains.items
- grains.ls
- grains.remove
- grains.setval
- grains.setvals
grains有如上方法,详细用法可以通过命令查看
salt ‘minion1‘ sys.doc grains
-----------------------------------------------------------------------
minion通过配置文件定义,这种方法很简单就是修改minion的配置文件
vim /etc/salt/minion,注释部分有这么一段
#grains:
# roles:
# - webserver
# - memcache
# deployment: datacenter4
# cabinet: 13
# cab_u: 14-15
为了统一控制grains可以将信息集中写到文件中
grains可以按照这种YAML格式进行修改和定义
/etc/salt/grains
grains:
roles:
- webserver
- memcache
deployment: datacenter4
cabinet: 13
cab_u: 14-15
重启minion使之生效
salt ‘minion1‘ grains.item grains:roles
minion1:
----------
grains:roles:
- webserver
- memcache
--------------------------------------------------------------------------------
通过Grains模块定义Grains
salt ‘minion1‘ grains.append saltbook ‘verycool‘
minion1:
----------
saltbook:
- verycool
[root[email protected] apache]# salt ‘minion1‘ grains.item saltbook
minion1:
----------
saltbook:
- verycool
可以使用grains.setvals同时设置多对Grains信息
salt ‘minion1‘ grains.setvals "{‘salt‘:‘good‘,‘book‘:‘cool‘}"
minion1:
----------
book:
cool
salt:
good
[[email protected] apache]# salt ‘minion1‘ grains.item salt
minion1:
----------
salt:
good
[[email protected] apache]# salt ‘minion1‘ grains.item book
minion1:
----------
book:
cool
当然也支持删除Grains信息,更多用法可以通过sys.doc grains命令查询
----------------------------------------------------------------------------
使用Python脚本方式添加grains方法我们后续再说