美文网首页saltstack
4-saltstack(2)_Grains组件

4-saltstack(2)_Grains组件

作者: 风逍H | 来源:发表于2017-10-26 20:41 被阅读12次

    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组件

        本文链接:https://www.haomeiwen.com/subject/stclpxtx.html