grains是Saltstack最重要的组件,grains的作用是手机被控主机的基本信息,这些信息通畅都是一些静态类数据,比如cpu、内核、操作系统、虚拟化等,在服务器端可以根据这些信息进行灵活定制,管理员可以利用这些信息对于不同的业务进行个性化设置,(初学时个人理解为:grains就是用来区分不同的minion进行不同的配置,salt '*' ,主要就是在'*' 里面进行匹配主机的作用)
1、grains常用操作命令
匹配内核版本为2.6.32-358.14.1.el6.x86_64的minion并执行命令'uname -a'
salt -G 'kernelrelease:2.6.32-358.14.1.el6.x86_64' cmd.run 'uname -a'
获取所有minion的grains项信息
salt '*' grains.ls
当然也可以获取主机单项grains数据,如获取操作发行版本,
salt 'SN2013-08-022' grains.item os
2、定义grains数据
定义grains数据的方法有两种,其中一种是在minion定制配置文件,另外一种是通过master扩展模块API实现,区别是模块更灵活,可用过Python编程动态定义,而配置文件只适合相对的固定的key与value。下面举例说明
(1)minion定制静态grains数据
SSH登录minion,配置文件定制的路径为/etc/salt/minion,参数为default_include:minion.d/*conf,打开次选项##注意前面留空格
创建文件【/etc/salt/minion.d/hostinfo.conf】
grains:
roles:
- webserver
- memcache
deployment: datacenter4
cabinet: 14
重启minion服务,验证结果在master上运行:salt 'SN2013-08-022' grains.item roles deployment cabinet,观察配置的key和value
(2)master扩展模块定制grains数据
首先在master编写Python代码,然后将Python文件同步到minion上,最后刷新生效(即编译Python源代码文件成字节码pyc)。在主控端base目录(见/etc/salt/master配置文件的file_roots项,默认base配置在/srv/salt)下生成_grains目录,执行install -d /srv/salt/_grains开始编写代码
import os,sys,commands def grains_openfile(): grains = {} _open_file=65533 try: getulimit=commands.getstatusoutput('source /etc/profile;ulimit -n') except Exception,e: pass if getulimit[0]==0: _open_file=int(getulimit[1]) grains['max_open_file'] = _open_file return grains
-
grains_openfile()定义一个获取最大打开文件数的函数,函数名称没有要求,符合Python函数命名规则即可。
-
grains={} 初始化一个grains字典,变量名一定要用grains,以便saltstack识别
-
grains['max_open_file']=_open_file 将获取的Linux ulimit -n的结果值赋予grains['max_open_file'],其中"max_open_file"就是grains的项,_open_file就是grains的值。
在主控端同步模块:salt 'SN2013-08-022' saltutil.sync_grains 或 salt 'SN2013-08-022' saltutil.sync_all,此时文件已经同步到被控端主机以下目录中,如下:
/var/cache/salt/minion/extmods/grains/grains_openfile.py和grains_openfile.pyc
/var/cache/salt/minion/files/base/_grains/grains_openfile.py
/var/cache/salt/minion/extmods/grains/ 为扩展模块文件最终存放位置,刷新模块后将在同路径下生成字节码pyc ;
/var/cache/salt/minion/files/base/_grains/ 为临时存放位置
在主控端进行校验,执行salt 'SN2013-08-022' grains.item max_open_file