zoukankan      html  css  js  c++  java
  • Saltstack学习(二)-数据系统

    saltstack主要有两种数据系统:

    • Grains
    • Pillar

    一、数据系统-Grains

    1.1、Grains简介

    1)当minion启动后会收集自身的状态信息即grains信息,grains信息是静态的,存储在minion端,如操作系统版本,内核版本,CPU,内存,硬盘,设备型号等。这些信息可以作为master端的匹配目标

    2)master端可以自定义grains设置,但需要执行命令推送到minion端

    3)master端推送的数据会存放在minion端的/var/cache/salt

    grains官方文档:https://docs.saltstack.com/en/latest/topics/grains/

    刷新grains的方法

    1、重启minion
    2、master强制刷新:salt '*' saltutil.sync_grains或者saltutil.sync_all
    

    1.2、使用grains查询minion端相关信息

    1)salt '*' grains.ls  ==>列出所有可打印的状态模块

    [root@salt-master ~]# salt 'salt-minion1-c7' grains.ls
    salt-minion1-c7:
        - SSDs
        - biosreleasedate
        - biosversion
        - cpu_flags
        - cpu_model
        - cpuarch
        - disks
        - dns
        - domain
        - fqdn
        - fqdn_ip4
        - fqdn_ip6
        - fqdns
        - gid
        - gpus
        - groupname
        - host
        - hwaddr_interfaces
        - id
        - init
        - ip4_gw
        - ip4_interfaces
        - ip6_gw
        - ip6_interfaces
        - ip_gw
        - ip_interfaces
        - ipv4
        - ipv6
        - kernel
        - kernelrelease
        - kernelversion
        - locale_info
        - localhost
        - lsb_distrib_codename
        - lsb_distrib_id
        - machine_id
        - manufacturer
        - master
        - mdadm
        - mem_total
        - nodename
        - num_cpus
        - num_gpus
        - os
        - os_family
        - osarch
        - oscodename
        - osfinger
        - osfullname
        - osmajorrelease
        - osrelease
        - osrelease_info
        - path
        - pid
        - productname
        - ps
        - pythonexecutable
        - pythonpath
        - pythonversion
        - saltpath
        - saltversion
        - saltversioninfo
        - selinux
        - serialnumber
        - server_id
        - shell
        - swap_total
        - systemd
        - uid
        - username
        - uuid
        - virtual
        - zfs_feature_flags
        - zfs_support
        - zmqversion
    

    2)salt '*' grains.items  ==>列出状态信息

    [root@salt-master ~]# salt 'salt-minion1-c7' grains.items
    salt-minion1-c7:
        ----------
        SSDs:
        biosreleasedate:
            05/19/2017
        biosversion:
            6.00
        cpu_flags:
            - fpu
            - vme
            - de
            - pse
            - tsc
            - msr
            - pae
            - mce
            - cx8
            - apic
            - sep
            - mtrr
            - pge
            - mca
            - cmov
            - pat
            - pse36
            - clflush
            - mmx
            - fxsr
            - sse
            - sse2
            - ss
            - syscall
            - nx
            - pdpe1gb
            - rdtscp
            - lm
            - constant_tsc
            - arch_perfmon
            - nopl
            - xtopology
            - tsc_reliable
            - nonstop_tsc
            - eagerfpu
            - pni
            - pclmulqdq
            - ssse3
            - fma
            - cx16
            - pcid
            - sse4_1
            - sse4_2
            - x2apic
            - movbe
            - popcnt
            - tsc_deadline_timer
            - aes
            - xsave
            - avx
            - f16c
            - rdrand
            - hypervisor
            - lahf_lm
            - abm
            - 3dnowprefetch
            - fsgsbase
            - tsc_adjust
            - bmi1
            - avx2
            - smep
            - bmi2
            - invpcid
            - rdseed
            - adx
            - smap
            - xsaveopt
            - arat
        cpu_model:
            Intel(R) Core(TM) i7-8550U CPU @ 1.80GHz
        cpuarch:
            x86_64
        disks:
            - sda
            - sr0
        dns:
            ----------
            domain:
            ip4_nameservers:
                - 223.5.5.5
            ip6_nameservers:
            nameservers:
                - 223.5.5.5
            options:
            search:
            sortlist:
        domain:
        fqdn:
            salt-minion1-c7
        fqdn_ip4:
            - 10.0.0.21
        fqdn_ip6:
            - fe80::20c:29ff:fe3e:9d2f
        fqdns:
        gid:
            0
        gpus:
            |_
              ----------
              model:
                  SVGA II Adapter
              vendor:
                  vmware
        groupname:
            root
        host:
            salt-minion1-c7
        hwaddr_interfaces:
            ----------
            eth0:
                00:0c:29:3e:9d:2f
            lo:
                00:00:00:00:00:00
        id:
            salt-minion1-c7
        init:
            systemd
        ip4_gw:
            10.0.0.254
        ip4_interfaces:
            ----------
            eth0:
                - 10.0.0.21
            lo:
                - 127.0.0.1
        ip6_gw:
            False
        ip6_interfaces:
            ----------
            eth0:
                - fe80::20c:29ff:fe3e:9d2f
            lo:
                - ::1
        ip_gw:
            True
        ip_interfaces:
            ----------
            eth0:
                - 10.0.0.21
                - fe80::20c:29ff:fe3e:9d2f
            lo:
                - 127.0.0.1
                - ::1
        ipv4:
            - 10.0.0.21
            - 127.0.0.1
        ipv6:
            - ::1
            - fe80::20c:29ff:fe3e:9d2f
        kernel:
            Linux
        kernelrelease:
            3.10.0-693.el7.x86_64
        kernelversion:
            #1 SMP Tue Aug 22 21:09:27 UTC 2017
        locale_info:
            ----------
            defaultencoding:
                UTF-8
            defaultlanguage:
                en_US
            detectedencoding:
                UTF-8
        localhost:
            salt-minion1-c7
        lsb_distrib_codename:
            CentOS Linux 7 (Core)
        lsb_distrib_id:
            CentOS Linux
        machine_id:
            6a95166986604960b8a690e6e5103d2f
        manufacturer:
            VMware, Inc.
        master:
            10.0.0.11
        mdadm:
        mem_total:
            976
        nodename:
            salt-minion1-c7
        num_cpus:
            1
        num_gpus:
            1
        os:
            CentOS
        os_family:
            RedHat
        osarch:
            x86_64
        oscodename:
            CentOS Linux 7 (Core)
        osfinger:
            CentOS Linux-7
        osfullname:
            CentOS Linux
        osmajorrelease:
            7
        osrelease:
            7.4.1708
        osrelease_info:
            - 7
            - 4
            - 1708
        path:
            /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin
        pid:
            15941
        productname:
            VMware Virtual Platform
        ps:
            ps -efHww
        pythonexecutable:
            /usr/bin/python
        pythonpath:
            - /usr/bin
            - /usr/lib64/python27.zip
            - /usr/lib64/python2.7
            - /usr/lib64/python2.7/plat-linux2
            - /usr/lib64/python2.7/lib-tk
            - /usr/lib64/python2.7/lib-old
            - /usr/lib64/python2.7/lib-dynload
            - /usr/lib64/python2.7/site-packages
            - /usr/lib64/python2.7/site-packages/gtk-2.0
            - /usr/lib/python2.7/site-packages
        pythonversion:
            - 2
            - 7
            - 5
            - final
            - 0
        saltpath:
            /usr/lib/python2.7/site-packages/salt
        saltversion:
            2019.2.0
        saltversioninfo:
            - 2019
            - 2
            - 0
            - 0
        selinux:
            ----------
            enabled:
                False
            enforced:
                Disabled
        serialnumber:
            VMware-56 4d e6 d4 88 d2 ac 39-c3 e1 9b 64 a5 3e 9d 2f
        server_id:
            1333013820
        shell:
            /bin/sh
        swap_total:
            2047
        systemd:
            ----------
            features:
                +PAM +AUDIT +SELINUX +IMA -APPARMOR +SMACK +SYSVINIT +UTMP +LIBCRYPTSETUP +GCRYPT +GNUTLS +ACL +XZ -LZ4 -SECCOMP +BLKID +ELFUTILS +KMOD +IDN
            version:
                219
        uid:
            0
        username:
            root
        uuid:
            d4e64d56-d288-39ac-c3e1-9b64a53e9d2f
        virtual:
            VMware
        zfs_feature_flags:
            False
        zfs_support:
            False
        zmqversion:
            4.1.4
    

    3)salt '*' grains.item fqdn_ip4  ==>列出特定的状态项,如获取minion的ip地址

    [root@salt-master ~]# salt '*' grains.item fqdn_ip4
    salt-minion1-c7:
        ----------
        fqdn_ip4:
            - 10.0.0.21
    salt-minion2-c7:
        ----------
        fqdn_ip4:
            - 10.0.0.22
    salt-minion3-c7:
        ----------
        fqdn_ip4:
            - 10.0.0.23
    salt-minion4-c6:
        ----------
        fqdn_ip4:
    [root@salt-master ~]# salt 'salt-minion4-c6' grains.item ip4_interfaces:eth0
    salt-minion4-c6:
        ----------
        ip4_interfaces:eth0:
            - 10.0.0.24
    

    4)salt '*' grains.get [key]  ==>获取相关信息

    [root@salt-master ~]# salt '*' grains.get saltversion
    salt-minion2-c7:
        2019.2.0
    salt-minion1-c7:
        2019.2.0
    salt-minion3-c7:
        2019.2.0
    salt-minion4-c6:
        2019.2.0
    
    [root@salt-master ~]# salt '*' grains.get ip4_interfaces:eth0
    salt-minion1-c7:
        - 10.0.0.21
    salt-minion2-c7:
        - 10.0.0.22
    salt-minion3-c7:
        - 10.0.0.23
    salt-minion4-c6:
        - 10.0.0.24

    5)salt –G   ==>指定匹配目标的主机执行命令

    [root@salt-master ~]# salt -G 'osmajorrelease:7' cmd.run 'uptime'   #在centos7上执行,centos6不执行
    salt-minion1-c7:
         00:10:36 up  5:30,  2 users,  load average: 0.00, 0.01, 0.05
    salt-minion2-c7:
         00:10:36 up  5:30,  2 users,  load average: 0.08, 0.05, 0.05
    salt-minion3-c7:
         00:10:36 up  5:30,  2 users,  load average: 0.04, 0.03, 0.05
    [root@salt-master ~]# salt -G 'os:CentOS' cmd.run 'uptime'    #在系统是centos的主机上执行
    salt-minion3-c7:
         00:10:56 up  5:30,  2 users,  load average: 0.03, 0.03, 0.05
    salt-minion2-c7:
         00:10:56 up  5:30,  2 users,  load average: 0.05, 0.05, 0.05
    salt-minion4-c6:
         08:09:26 up  5:28,  2 users,  load average: 0.00, 0.00, 0.00
    salt-minion1-c7:
         00:10:56 up  5:30,  2 users,  load average: 0.00, 0.01, 0.05

    1.3、根据minion端自定义的grains,执行远程目标匹配

    #编辑minion端的配置文件,自定义grains
    [root@salt-minion1-c7 ~]# vim /etc/salt/minion
    grains:
      roles:
        - webserver
      os_version:
        - centos7.5
    
    #重启minion
    [root@salt-minion1-c7 ~]# systemctl restart salt-minion
    
    #master端执行目标匹配
    [root@salt-master ~]# salt -G 'roles:webserver' test.ping 
    salt-minion1-c7:
        True
    [root@salt-master ~]# salt -G 'os_version:centos7.5' test.ping 
    salt-minion1-c7:
        True

    1.4、Master端编写一个GrainsPython脚本推送给minion

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

    自定义python脚本格式:

    def 自定义函数名():
        grains = {}
        grains['需要添加的grain item 名字'] = 命令行获取方法
        return grains

    获取系统时间实例:

    #在master端自定义python脚本
    [root@salt-master ~]# cat /srv/salt/_grains/get_time.py
    #!/usr/bin/env python
    #-*- 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@salt-master ~]# salt '*' saltutil.sync_grains
    salt-minion1-c7:
        - grains.get_time
    salt-minion4-c6:
        - grains.get_time
    salt-minion2-c7:
        - grains.get_time
    salt-minion3-c7:
        - grains.get_time
    
    [root@salt-master ~]# salt '*' grains.get server_time
    salt-minion2-c7:
        2019-08-31 10:17:10
    salt-minion1-c7:
        2019-08-31 10:17:10
    salt-minion3-c7:
        2019-08-31 10:17:10
    salt-minion4-c6:
        2019-08-31 18:16:39
    
    #Minion存放Master同步来的脚本目录
    [root@salt-minion1-c7 ~]# ll /var/cache/salt/minion/extmods/grains/
    -rw------- 1 root root 206 Aug 31 10:17 get_time.py
    -rw------- 1 root root 443 Aug 31 10:17 get_time.pyc

    1.5、grains定义优先级

    默认grains信息>minion配置文件定义>master定义的grains推送

    二、数据系统-Pillar

    1.1、Pillar简介

    Pillar是动态的,Pillar存储在master端,提供给minion端
    Pillar主要记录一些加密信息, 可以确保这些敏感数据不被其他minion看到。
    Pillar在SaltStack中主要作用是存储和定义配置管理中需要的一些数据,比如软件版本号、用户名密码等信息,它的存储格式跟Grains类似,都是YAML格式。

    pillar官方文档:https://docs.saltstack.com/en/latest/topics/pillar/

    pillar相关文件:

    • 默认目录: /srv/pillar/, 在master配置文件中指定,目录默认需要自己创建。修改配置文件可修改。
    • 入口文件: /srv/pillar/top.sls , pillar默认的主入口配置文件。
    • Pillar默认值:与grains不同,所有的pillar值都是人为设定的,默认pillar为空。
    • sls 文件:pillar的文件,sls是saltstack的缩写,YAML风格,支持jinja模板。

    1.2、Pillar相关命令

    salt '*' sys.doc pillar            # 查看与pillar有关的帮助信息
    salt '*' pillar.items              # 获取所有pillar items值
    salt '*' pillar.data               # 等价于pillar.items
    salt '*' saltutil.refresh_pillar   # 刷新pillar值
    salt '*' saltutil.sync_all         # 刷新pillar值,与refresh_pillar操作类似,但范围更大
    salt '*' sys.list_functions pillar # 列出所有的pillar相关函数方法
    salt '*' pillar.get xxx            # 获取某项的值,类似于python字典的get函数
    salt '*' pillar.raw                 # 内存中获取
    salt '*' state.highstate pillar={'test': 'abc'}  # 在命令设置pillar 数据

    1.3、master配置Pillar相关信息

    (1)pillar目录
    pillar_roots:
      base:
        - /srv/pillar
    
    (2)是否将master配置文件中的数据信息添加到pillar中,默认是不加,需要的话可以改成True,重启服务生效。
    pillar_opts: False
    
    (3)pillar 源,salt支持引入pillar外部资源,例如从数据库导入pillar值,默认是关闭的
    ext_pillar_first: False
    
    (4)开启pillar gitgs ssl验证
    pillar_gitfs_ssl_verify: True
    
    (5)开启pillar render 错误信息
    pillar_safe_render_error: True
    
    (6)设置pillar配置合并策略
    pillar_source_merging_strategy: smart

    1.4、Pillar刷新方式

    1)salt '*' saltutil.refresh_pillar

    2)salt '*' saltutil.sync_all

    1.5、Pillar的sls文件说明

    默认文件入口:/src/pillar/top.sls

    top.sls的引用有两种

    1)将引用sls文件放在同级目录

    [root@saltmaster srv]# tree /srv/pillar/
    /srv/pillar/       # 默认pillar文件目录
    ├── packages.sls   # packages 引用文件
    ├── services.sls   # services 引用文件
    └── top.sls        # 固定的入口文件top.sls

    2)在/src/pillar/ 目录下创建对应的packages, services目录,并在该目录下创建init.sls文件

    [root@saltmaster srv]# tree /srv/pillar/
    /srv/pillar/
    ├── packages       # packages 目录
    │   └── init.sls   # 引用文件
    ├── services       # services 目录
    │   └── init.sls   # 引用文件
    └── top.sls        # 固定的入口文件top.sls

    备注:如果要引用执行的sls文件和目录同时存在,也就是方法一和方法二都存在,packages.sls和packages/init.sls,会优先使用packages.sls文件

    1.6、Pillar使用

    1)在master端定义Pillar

    [root@salt-master ~]# vim /etc/salt/master
    pillar_roots:
       base:
         - /srv/pillar
      
    [root@salt-master ~]# vim /etc/salt/master
    [root@salt-master ~]# systemctl restart salt-master
    [root@salt-master ~]# mkdir /srv/pillar
    [root@salt-master ~]# cd /srv/pillar

    2)定义sls文件

    [root@salt-master pillar]# cat zabbix.sls 
    zabbix:
      package-name: zabbix
      version: 3.2.4
      port: 10050
      user: admin
    
    #定义topfile
    [root@salt-master pillar]# cat top.sls 
    base:
      'salt-minion1-c7':
         - zabbix

    3)刷新pillar

    [root@salt-master pillar]# salt '*' saltutil.refresh_pillar

    4)获取对应的pillar值

    [root@salt-master pillar]# salt 'salt-minion1-c7' pillar.item zabbix
    salt-minion1-c7:
        ----------
        zabbix:
            ----------
            package-name:
                zabbix
            port:
                10050
            user:
                admin
            version:
                3.2.4
    

    三、Pillar与Grains对比

    类型 数据采集方式 应用场景 定义位置
    Grains 静态,minion启动时采集 用于数据查询,目标选择,配置管理 minion
    Pillar 动态,master上定义 用于目标选择,配置管理,敏感数据 master
  • 相关阅读:
    mybatis做like模糊查询
    mysql带有子查询的like查询
    form表单提交,后台怎么获取select的值?后台直接获取即可,和input方式一样。
    Spring MVC 向页面传值-Map、Model和ModelMap
    JavaWeb登录、注销、退出、记住用户名和密码
    EL表达式多条件或判断用法
    三级分销会员一次查询出来的SQL语句
    mysql 中合并查询结果union用法 or、in与union all 的查询效率
    关于取List中的指定几条数据以及注意事项
    BoxedApp Packer 将您的原始应用“打包”成单个完全的可执行二进制文件
  • 原文地址:https://www.cnblogs.com/hujinzhong/p/11437642.html
Copyright © 2011-2022 走看看