简介

  Grains 是SaltStack 的重要组件之一。主要记录minion的静态信息,比如CPU,内存,磁盘,网络信息等。Grains信息是minion启动时汇报给Master的。

刷新grains方法:
  (1)重启minion
  (2)Master强制刷新: salt '*' saltutil.sync_grains

Grains 相关方法

Grains:
- grains.append # 向grains中添加key/value, 不存在则创建,存在则追加,被追加的key将有两个值,salt '*' grains.append key val. 特别注意:append 操作要时 key必须是个列表
- grains.delkey # 删除指定的grains key,value也会一起删除。salt '*' grains.delkey key
- grains.delval # 删除指定的grains key 的 value值,并不会删除key,主要注意删除value后会将value变成None. salt '*' grains.delval key
- grains.equals # 判断key/value 是否匹配,匹配返回True,反之则为False. salt '*' grains.equals key value
- grains.fetch # 获取指定key的value值,如果不存在则返回空字符串,和get类似。 salt "*" grains.fetch key
- grains.filter_by # 过滤查找
- grains.get # 获取, 和fetch类似
- grains.get_or_set_hash # salt '*' grains.get_or_set_hash 'django:SECRET_KEY' 50
- grains.has_value # salt '*' grains.has_value pkg:apache
- grains.item # 获取指定grains item信息(也可以获取多个,多个用空格分隔),例如: grains.item wan, 获取wan的信息
[root@iz8vb7vqedcq5amxidjpaiz ~]# salt '*' grains.item wan
minion:
----------
wan:
41.2.2.2
- grains.items # 获取minion的所有grains item信息
- grains.ls # 获取grains的所有item key值
- grains.remove # 和append 对应,移除grains key 的value 列表中的一个。salt '*' grains.remove key val
- grains.set # 设置key 为任意值,value是嵌套模式的。
# salt '*' grains.set 'apps:myApp:port' 2209
# salt '*' grains.set 'apps:myApp' '{port: 2209}'
- grains.setval # 设置key . salt '*' grains.setval key val
# salt '*' grains.setval key "{'sub-key': 'val', 'sub-key2': 'val2'}"
[root@iz8vb7vqedcq5amxidjpaiz ~]# salt '*' grains.setval key11 "{'sub-key': 'val', 'sub-key2': 'val2'}"
minion:
----------
key11:
----------
sub-key:
val
sub-key2:
val2
[root@iz8vb7vqedcq5amxidjpaiz ~]# salt '*' grains.item key11:sub-key
minion:
----------
key11:sub-key:
val
[root@iz8vb7vqedcq5amxidjpaiz ~]# salt '*' grains.item key11:sub-key2
minion:
----------
key11:sub-key2:
val2
- grains.setvals # 设置多个key/value,salt '*' grains.setvals "{'key1': 'val1', 'key2': 'val2'}"
[root@iz8vb7vqedcq5amxidjpaiz ~]# salt '*' grains.setvals "{'key1': 'val1', 'key2': 'val2'}"
minion:
----------
key1:
val1
key2:
val2

Grains 方法说明

系统默认Grains 内容

[root@yw_home ~]# salt 192.168.0.100 grains.items
192.168.0.100:
biosreleasedate: 03/11/2013
biosversion: 1.5.2
cpu_flags: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx pdpe1gb rdtscp lm constant_tsc arch_perfmon pebs bts rep_good xtopology nonstop_tsc aperfmperf pni pclmulqdq dtes64 monitor ds_cpl vmx smx est tm2 ssse3 cx16 xtpr pdcm pcid dca sse4_1 sse4_2 x2apic popcnt tsc_deadline_timer aes xsave avx lahf_lm ida arat xsaveopt pln pts dts tpr_shadow vnmi flexpriority ept vpid
cpu_model: Intel(R) Xeon(R) CPU E5-2420 0 @ 1.90GHz
cpuarch: x86_64
defaultencoding: UTF8
defaultlanguage: en_US
domain: localdomain
external_ip: 192.168.0.100
fqdn: localhost.localdomain
fqdn_ip4:
127.0.0.1
fqdn_ip6:
::1
gpus:
{'model': 'G200eR2', 'vendor': 'unknown'}
host: localhost
hwaddr_interfaces: {'lo': '00:00:00:00:00:00', 'em1': '保密隐去', 'em2': '保密隐去'}
id: 192.168.0.100
ip_interfaces: {'lo': ['127.0.0.1'], 'em1': ['192.168.0.100'], 'em2': []}
ipv4:
127.0.0.1
192.168.0.100
ipv6:
::1
fe80::92b1:1cff:fe50:d4ac
kernel: Linux
kernelrelease: 2.6.32-431.el6.x86_64
localhost: 192.168.0.100
manufacturer: Dell Inc.
master: 192.168.0.100
mem_total: 64377
nodename: 192.168.0.100
num_cpus: 24
num_gpus: 1
os: CentOS
os_family: RedHat
osarch: x86_64
oscodename: Final
osfinger: CentOS-6
osfullname: CentOS
osmajorrelease:
6
5
osrelease: 6.5
path: /sbin:/usr/sbin:/bin:/usr/bin
productname: PowerEdge R420
ps: ps -efH
pythonpath:
/usr/bin
/usr/lib64/python26.zip
/usr/lib64/python2.6
/usr/lib64/python2.6/plat-linux2
/usr/lib64/python2.6/lib-tk
/usr/lib64/python2.6/lib-old
/usr/lib64/python2.6/lib-dynload
/usr/lib64/python2.6/site-packages
/usr/lib64/python2.6/site-packages/gtk-2.0
/usr/lib/python2.6/site-packages
/usr/lib/python2.6/site-packages/setuptools-0.6c11-py2.6.egg-info
pythonversion: 2.6.6.final.0
saltpath: /usr/lib/python2.6/site-packages/salt
saltversion: 2014.1.0
saltversioninfo:
2014
1
0
serialnumber: 保密隐去
server_id: 保密隐去
shell: /bin/sh
virtual: physical

默认grains内容

自定义Grains

  当我们需求更多,默认grains不能满足时,可以自定义grains.

自定义Grains的方式

  (1)通过minion配置文件定义, 优先级1
  (2)通过Master端对Grains定义,优先级3
  (3)通过Master端python脚本定义, 优先级2

自定义grains优先级:

  minion配置文件定义 > master端自定义grains脚本 > master端grains模块定义。

特别注意:

  在 /src/salt/_grains目录下的自定义脚本,在执行完成后,建议移到一个Bak目录,确保_grains中没有残留文件,并在执行一次salt'*'saltutil.sync_grains操作。

使minion主机上自定义模块目录是干净的,这样做的好处是可以避免和另外两个文件有配置冲突,也避免脚本之间有重复的名字定义,造成取值结果错误。

(1)minion配置文件定义

  在minion端,grains 默认的配置文件路径写在minion文件中:default_include: minion.d/*.conf , 需要自己创建 *.conf 这个文件。并在文件中按照YAML格式编写grains配置文件。

需要重启Minion后 Master才能获取最新的grains信息(或者Master主动去刷新)。

# cat grains.conf
# 特别注意 :和 - 后面需要接一个空格,段落开头是2个空格间距
grains:
roles:
- webserver
- memcache
deployment: datacenter4
cabinet: 13
cab_u: 14-15
serverid: 1001
# Master 查看grains信息
[root@saltmaster salt]# salt 'salt-min*' grains.item serverid
salt-minion-1:
----------
serverid:
1001

(2)Master端对Grains定义

  通过Master 直接给minion 设定Grains数据,而且不需要重启minion,即可生效。通过Master设定的Grains数据保存在minion端的/etc/salt/grains 文件中。格式依旧遵循YAML。

# Master 向 Minion 添加一个name变量,内容为node1
[root@saltmaster salt]# salt 'salt-min*' grains.append name 'node1'
salt-minion-1:
----------
name:
- node1
# 在次向name变量添加内容时,并不会覆盖,而是追加,name将有2个值
[root@saltmaster salt]# salt 'salt-min*' grains.append name 'node2'
salt-minion-1:
----------
name:
- node1
- node2
# Master 向 Minion 添加多个数据,通过grains.setvals 内容则是一个字典的形式
[root@saltmaster salt]# salt 'salt-min*' grains.setvals "{'serverid':'1002','other':'hi'}"
salt-minion-1:
----------
other:
hi
serverid:
1002
# Master 获取指定Minion 中 grains数据值, grains.item 直接加变量名(一个或多个皆可)
[root@saltmaster salt]# salt 'salt-min*' grains.item name serverid
salt-minion-1:
----------
name:
- node1
- node2
serverid:
1001
# Master 直接获取 Minion 的Grains变量内容
[root@saltmaster salt]# salt 'salt-min*' grains.get name
salt-minion-1:
- node1
- node2

(3)Master端python脚本定义

  默认自定义脚本需要放在 Master 的 /srv/salt/_grains 目录下, 这个目录需要自己创建。同步到Minion的脚本会被放在 minion 的 /var/cache/salt/minion/extmods/grains/ 。

# 自定义grains python脚本格式,类似于创建一个grains空字典并添加一对key/value:
def 自定义函数名():
grains = {}
grains['需要添加的grain item 名字'] = 命令行获取方法
return grains # 获取系统时间的示例
[root@salt-minion-1 salt]# cat /var/cache/salt/minion/extmods/grains/get_time.py
#!/usr/bin/python env
# coding=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
# 使用 sync_grains 命令同步脚本到Minion主机上,并通过grains.item 命令获取相关信息即可。
[root@saltmaster salt]# salt "*" saltutil.sync_grains
saltmaster:
- grains.get_time
salt-minion-1:
- grains.get_time
[root@saltmaster salt]# salt '*' grains.item server_time
salt-minion-1:
----------
server_time:
2017-06-08 16:56:55
saltmaster:
----------
server_time:
2017-06-08 16:56:54
# Minion 存放 Master 同步来的脚本目录
[root@salt-minion-1 salt]# ll /var/cache/salt/minion/extmods/grains/
total 8
-rw-------. 1 root root 197 Jun 8 16:56 get_time.py
-rw-------. 1 root root 443 Jun 8 16:56 get_time.pyc

SaltStack Grains 详解的更多相关文章

  1. SaltStack Pillar 详解

    简介 grains用于存储静态不易变更的数据,而pillar一般用于存储动态, 敏感的数据,通过minion和master设置或获取grains信息,而pillar信息只能在master端配置,在到m ...

  2. saltstack配置文件详解

    软件依赖 Python版本大于2.6或版本小于3.0: 对Python版本要求 msgpack-python: SalStack消息交换库 YAML: SaltStack配置解析定义语法 Jinja2 ...

  3. SaltStack系列(一)之环境部署、命令及配置文件详解

    一.SaltStack介绍 1.1 saltstack简介: saltstack是基于python开发的一套C/S架构配置管理工具,它的底层使用ZeroMQ消息队列pub/sub方式通信,使用SSL证 ...

  4. saltstack自动化运维系列⑤之saltstack的配置管理详解

    saltstack自动化运维系列⑤之saltstack的配置管理详解 配置管理初始化: a.服务端配置vim /etc/salt/master file_roots: base: - /srv/sal ...

  5. SaltStack 入门到精通第三篇:Salt-Minion配置文件详解

    SaltStack 入门到精通第三篇:Salt-Minion配置文件详解 作者:ArlenJ  发布日期:2014-06-09 17:52:16   ##### 主要配置设置 ##### 配置 默认值 ...

  6. SaltStack 入门到精通第二篇:Salt-master配置文件详解

    SaltStack 入门到精通第二篇:Salt-master配置文件详解     转自(coocla):http://blog.coocla.org/301.html 原本想要重新翻译salt-mas ...

  7. Python3安装使用SaltStack以及salt-api详解

    序言 最近在使用salt-api做主机批量管理部署,整理一下文档.之前使用saltstack 多用于命令行管理,自己做web版的自动化管理平台时,发现命令行的些许局限性,接触到salt-api,找到了 ...

  8. saltstack源码详解一

    目录 初识源码流程 入口 1.grains.items 2.pillar.items 2/3: 是否可以用python脚本实现 总结pillar源码分析: @(python之路)[saltstack源 ...

  9. Saltstack的部署及其详解

    https://repo.saltstack.com/ Saltstack简介: salt是一个多平台基础设施管理工具通常只用在linux上,使用那个轻量级的通讯器,ZN用python写成的批量管理工 ...

随机推荐

  1. PLSQL启动很慢的问题

    最近重新做了系统,win7 64位系统上装了oracle10g,plsql10.发现plsql启动比较慢. 解决方法: 首先停止打印机服务:Print Spooler,然后将这个服务设置为手动模式.

  2. 怎样在Windows与Centos下的Linux间共享文件,如果mnt文件夹不显示,可能是mnt缺少共享支持

    mnt中的hgfs文件夹就是Linux系统中挂载共享文件的默认文件夹.有的人按步骤共享之后mnt中没有出现共享的文件,可能是因为你的mnt缺少共享支持. 此时可以在Terminal中输入:sudo m ...

  3. memcache can't run as root without the -u switch

    memcached是一款高速.分布式的内存缓存系统.其官方主页在http://www.danga.com/memcached/1.安装前的准备要安装memcached,需要有libevent的支持.c ...

  4. [mysql]设置Ubuntu上的MySQL可以远程访问

    今天在win10上用django连接安装在Ubuntu上的MySQL上,始终提示错误(can not connect mysql),但是在Ubuntu上访问是没有问题的.于是开始查找原因: 1. 33 ...

  5. 如何设计Kafka?

    著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处.作者:Sugar Su链接:http://zhuanlan.zhihu.com/ms15213/20545422来源:知乎 此文稿来 ...

  6. 解决 Laravel try catch 不工作的问题

    最近再用laravel框架发现,try catch用了没有效果,不能捕获异常, 然后在think框架里也试了一下,发现竟然也不可以! [php] view plain copy try{  $i = ...

  7. Zookeeper 源码(六)Leader-Follower-Observer

    Zookeeper 源码(六)Leader-Follower-Observer 上一节介绍了 Leader 选举的全过程,本节讲解一下 Leader-Follower-Observer 服务器的三种角 ...

  8. DataStage 六、安装和部署集群环境

    DataStage序列文章 DataStage 一.安装 DataStage 二.InfoSphere Information Server进程的启动和停止 DataStage 三.配置ODBC Da ...

  9. 如何查看服务器(linux系统)当前的负载信息(转)

    如何查看服务器当前的负载信息http://www.flybaaa.com/help 网吧内突然很卡,这个情况我相信大家都有遇见过,但是通过什么方法来排查是否linux服务器的负载过大导致的这个问题呢? ...

  10. zz如何让你的婚姻天长地久?

    如果天长地久意味着一列永不出轨的火车,下面有关婚姻生活的战略就像制定一张准确的运行时刻表.因为成功的婚姻并非源于机运,所谓的七年之痒也不是空穴来风.对那些已婚男人来说,他们需要计划——为了一年比一年过 ...