爱她吗 发表于 2018-7-31 09:05:28

saltstack state模块-状态管理

  一、说明
  本文基于前两篇的salstack的安装部署和使用的基础上,又一个常用的功能,
  State模块是saltstack核心的功能,状态管理包括:Package,File,Network,                     Service, User等常用功能,其他功能参考官方文档:
  https://docs.saltstack.com/en/latest/ref/states/all/index.html
  本次的实验环境依然和前面的一致两台。
  任务:通过grins,pillar,state向指定minion安装apache软件包,并启动。
  开启state的文件目录
  #cat-n /etc/salt/master
file_roots:  
   base:
  
   - /srv/salt
  二、pillar结合grains的文件编写
  主要通过pillar,grains给state提供特定安装条件
  1、pillar中的变量生成配置
  #cat /srv/pillar/top.sls
base:  
   "*":
  
      - apacheData
  #cat /srv/pillar/apacheData.sls
pkg:  
    {% if grains["os_family"] == "RedHat" %}
  
       apache: httpd
  
    {% else %}
  
       apache: apache2
  
    {% endif %}
  说明:通过 pillar,结合grains的os_family值,让apache的变量在minion端动态生成保存在pillar.data中;
  2、同步更新到minion
  #salt "*" saltutil.refresh_pillar
  此时可通过salt "*" pillar.data pkg如图:

  三、state文件编写
  1、states配置文件
  cat /srv/salt/top.sls
base:  
   "*":
  
      - apache
  cat /srv/salt/apache.sls
apache:  
   pkg:
  
      - installed
  
      - name: {{ pillar["pkg"]["apache"] }}
  
   service.running:
  
      - name: {{ pillar["pkg"]["apache"] }}
  
      - require:
  
         - pkg: {{ pillar["pkg"]["apache"] }}
  2、同步到minion
  测试是否有错误:
  # salt"*" state.highstate test=True
  如果没有问题
  #salt"*" state.highstate
  执行成功出现类似下面的提示

  验证:
  # salt -C "minion_local" cmd.run "service httpd status"
  minion_local:
  httpd (pid12909) is running...
  到此一个通过过pillar 结合grains 和state让客户端操持状态和任务下发完成。本文只是抛砖引玉,入门使用。欢迎交流指正。
页: [1]
查看完整版本: saltstack state模块-状态管理