4-saltstack(2)_Grains组件

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主机上自定义模块目录是干净的,这样做的好处是可以避免和另外两个文件有配置冲突,也避免脚本之间有重复的名字定义,造成取回的结果不对。

你可能感兴趣的:(4-saltstack(2)_Grains组件)