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主機上自定義模塊目錄是干凈的,這樣做的好處是可以避免和另外兩個文件有配置沖突,也避免腳本之間有重復的名字定義,造成取回的結果不對。