運維工具SaltStack之三Grains組件

運維工具SaltStack之三Grains組件node

1、grains組件介紹python

grains是收集Minion主機的靜態、不常變化的基本信息,存儲在Minion端本地,如:CPU、內核、操做系統、虛擬化等,而且服務器端能夠根據這些信息進行靈活定製或個性化定製,是Saltstack最重要的組件之一,多用來作資產管理的信息收集,主要解決平臺的差別性。bash

如能夠使用如下命令:服務器

#salt 'minion01' grains.items  #獲取minion01主機基本信息


2、grains組件自定義運維

    自定義grains有兩種方法:ide

    第一種Minion端配置,須要重啓minion生效(不建議使用);工具

    第二種在master端配置,同步以後生效,不須要重啓master或者minion(比較推薦該方法)。spa

1.在master端配置grains組件操作系統

1.1.使用默認的Master的file_roots配置路徑 /srv/salt建立_grains目錄debug

#cd /srv/salt && mkdir _grains

1.2.修改salt的Master主配置文件(/etc/salt/master),新增以下內容,而且須要重啓Master服務:

file_roots:
  base:
    - /srv/salt/
# systemctl restart salt-master.service

注意:yaml格式問題: 和 - 後有空格,當心縮進!!!!!!!!


1.3.使用python自定義腳本(注意返回值是一個字典)

#抓取服務器的運行時間

cat /srv/salt/_grains/runtime.py
#!/usr/bin/python
import commands
def runtime():
    grains = {}
    grains['days'] = commands.getoutput("uptime|awk -F'up|days' '{print $2}'")
    return runtime

1.4.用saltutil.sync_grains或者saltutil.sync_all將自定義的grains item 同步到Minion端,若是隻同步grains建議使用saltutil.sync_grains。

# salt 'minion01' saltutil.sync_grains -l debug
# salt 'minion01' sys.reload_modules  #刷新客戶端生效
[root@node03 _grains]# salt 'minion01' sys.reload_modules
minion01:
    True
# salt 'minion01' grains.item days #獲取自定義的grains)
[root@node03 _grains]# salt 'minion01' grains.item days
minion01:
    ----------
    days:
    1

注:同步完成後在Minion端的如下目錄中能夠找到Master下發的grains文件

# ls /var/cache/salt/minion/extmods/grains/
runtime.py  runtime.pyc


2.在master端配置grains組件經過states的grains方法也能夠自定義grains

2.1.在/srv/salt再建立getitem目錄

#cd /srv/salt && mkdir getitem

2.2.在getitem目錄新建test.sls,內容以下:

# cat test.sls
test:
  grains.present:
    - value: test

2.3.同步至minion01端,並檢查結果

# salt 'minion01' state.sls getitem.test
minion01:
----------
          ID: test
    Function: grains.present
      Result: True
     Comment: Set grain test to test
     Started: 17:28:48.807030
    Duration: 1032.356 ms
     Changes:   
              ----------
              test:
                  test
Summary
------------
Succeeded: 1 (changed=1)
Failed:    0
------------
Total states run:     1
# salt 'minion01' grains.get test
minion01:
    test

注:同步完成後在Minion端的如下目錄中(/etc/salt/grains)能夠找到Master下發的grains文件

# cat /etc/salt/grains 
test: test

注意:這裏不作自定義在Minion端操做示例,實際生產環境中通常沒有用。

相關文章
相關標籤/搜索