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