设为首页 收藏本站
查看: 1351|回复: 0

[经验分享] saltstack/salt的state.sls和pillar定义以及使用

[复制链接]

尚未签到

发表于 2018-7-31 07:46:06 | 显示全部楼层 |阅读模式
  SLS(代表SaLt State文件)是Salt State系统的核心。SLS描述了系统的目标状态,由格式简单的数据构成。这经常被称作配置管理 首先,在master上面定义salt的主目录,默认是在/srv/salt/下面,vim /etc/salt/master:
file_roots:  
   base:
  
     - /srv/salt
  
   dev:
  
    - /srv/salt-dev
  然后,在/srv/salt下面创建top.sls文件(如果有的话,就不用创建了,直接编辑好了) vim top.sls
base:  
  '*':
  top.sls 默认从 base 标签开始解析执行,下一级是操作的目标,可以通过正则,grain模块,或分组名,来进行匹配,再下一级是要执行的state文件
base:  
  '*':               #通过正则去匹配所有minion
  
    - nginx          #这里都是我自己写的state.sls模块名 这里可以无视 后面会提到
  

  
  my_app:             #通过分组名去进行匹配 必须要定义match:nodegroup
  
    - match: nodegroup
  
    - nginx
  

  
  'os:Redhat':        #通过grains模块去匹配,必须要定义match:grain
  
    - match: grain
  
    - nginx
  整个top.sls大概的格式就是这个样子,编写完top.sls后,编写state.sls文件;
cd /srv/salt  
vim nginx.sls
  nginx.sls内容:
nginx:  
  pkg:               #定义使用(pkg state module)
  
    - installed      #安装nginx(yum安装)
  
  service.running:   #保持服务是启动状态
  
    - enable: True
  
    - reload: True
  
    - require:
  
      - file: /etc/init.d/nginx
  
    - watch:                 #检测下面两个配置文件,有变动,立马执行上述/etc/init.d/nginx 命令reload操作
  
      - file: /etc/nginx/nginx.conf
  
      - file: /etc/nginx/fastcgi.conf
  
      - pkg: nginx
  
/etc/nginx/nginx.conf:       #绝对路径
  
  file.managed:
  
    - source: salt://files/nginx/nginx.conf  #nginx.conf配置文件在salt上面的位置
  
    - user: root
  
    - mode: 644
  
    - template: jinja   #salt使用jinja模块
  
    - require:
  
      - pkg: nginx
  

  
/etc/nginx/fastcgi.conf:
  
  file.managed:
  
    - source: salt://files/nginx/fastcgi.conf
  
    - user: root
  
    - mode: 644
  
    - require:
  
      - pkg: nginx
  在当前目录下面(salt的主目录)创建files/nginx/nginx.conf、files/nginx/fastcgi.conf文件,里面肯定是你自己项配置的nginx配置文件的内容啦;使用salt做自动化,一般nginx都是挺熟悉的,这里不做详细解释了
  测试安装:
root@salt salt # salt 'sa10-003' state.sls nginx test=True  
··········这里省略输出信息
  
Summary
  
------------
  
Succeeded: 8
  
Failed:    0
  
------------Total:     8
  往minion上面进行推送的时候,一般salt ‘sa10-003’ state.sls nginx 这种命令;当然,也可以执行 salt sa10-003 state.highstate 这种命令会默认匹配所有的state.sls模块。其中test=True 是指测试安装 ,也就是不进行实际操作,只是查看测试效果。
  state的逻辑关系列表:
  include: 包含某个文件 比如我新建的一个my_webserver.sls文件内,就可以继承nginx和php相关模块配置,而不必重新编写
root@salt salt # cat my_webserver.sls  
include:
  
  - nginx
  
  - php
  match: 配模某个模块,比如 之前定义top.sls时候的 match: grain match: nodegroup require: 依赖某个state,在运行此state前,先运行依赖的state,依赖可以有多个 比如文中的nginx模块内,相关的配置必须要先依赖nginx的安装
- require:  
  - pkg: nginx
  watch: 在某个state变化时运行此模块,文中的配置,相关文件变化后,立即执行相应操作
- watch:  
  - file: /etc/nginx/nginx.conf
  
  - file: /etc/nginx/fastcgi.conf
  
  - pkg: nginx
  order: 优先级比require和watch低,有order指定的state比没有order指定的优先级高,假如一个state模块内安装多个服务,或者其他依赖关系,可以使用
nginx:  
  pkg.installed:
  
    - order:1
  想让某个state最后一个运行,可以用last
  Pillar是Salt非常重要的一个组件,它用于给特定的minion定义任何你需要的数据,这些数据可以被Salt的其他组件使用。这里可以看出Pillar的一个特点,Pillar数据是与特定minion关联的,也就是说每一个minion都只能看到自己的数据,所以Pillar可以用来传递敏感数据(在Salt的设计中,Pillar使用独立的加密session,也是为了保证敏感数据的安全性)。 另外还可以在Pillar中处理平台差异性,比如针对不同的操作系统设置软件包的名字,然后在State中引用等。
定义pillar数据
  默认情况下,master配置文件中的所有数据都添加到Pillar中,且对所有minion可用。默认如下:
#pillar_opts: True  master上配置文件中定义pillar_roots,用来指定pillar的数据存储在哪个目录
pillar_roots:  
   base:
  
    - /srv/salt/pillar
  首先,和state系统一样,pillar也是需要一个top.sls文件作为一个入口,用来指定对象。
base:  
  '*':
  
    - pillar #这里指定了一个pillar模块
  pillar.sls文件:
############IDC################  
{% if grains['ip_interfaces'].get('eth0')[0].startswith('10.10') %}
  
nameservers: ['10.10.9.31','10.10.9.135']
  
zabbixserver: ['10.10.9.234']
  
{% else %}
  
nameservers: ['10.20.9.75']
  
zabbixserver: ['10.20.9.234']
  
{% endif %}
  

  
######## nginx ########
  
ngx_home_dir: /var/cache/nginx
  上文的IDC这块是我自己整理的通过ip来划分不同的nameserver等,这里只是放出来参考,在State文件中将可以引用Pillar数据,比如引用
  ngx_home_dir:
nginx:  
  pkg:
  
    - installed
  
  user.present:
  
    - home: {{ pillar['ngx_home_dir'] }}
  
    - shell: /sbin/nologin
  
    - require:
  
      - group: nginx
  
  group.present:
  
    - require:
  
      - pkg: nginx
  
  service.running:
  
    - enable: True
  
    - reload: True
  
    - require:
  
      - file: /etc/init.d/nginx
  
      - file: /data1/logs/nginx
  
    - watch:
  
      - file: {{ pillar['ngx_conf_dir'] }}/nginx.conf
  
      - file: {{ pillar['ngx_conf_dir'] }}/fastcgi.conf
  
      - pkg: nginx
  

  
······ 后面关于配置就省略了
  在pillar内可以提前将不同的部分根据在pillar内定义好,这样统一配置的时候就可以实现根据机器实际情况配置;比如根据机器的硬件情况配置nginx的worker_processes:
user nginx;  
{% if grains['num_cpus'] < 8 %}
  
worker_processes {{ grains['num_cpus'] }};
  
{% else %}
  
worker_processes 8;
  
{% endif %}
  
worker_rlimit_nofile 65535;
  
``````````具体配置省略
  很多定义的时候,都可以使用到pillar来进行自定义相关数据,具体情况可以自行摸索,这里只是个举例。
  系统运维工程师:李超

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-543822-1-1.html 上篇帖子: SaltStack配置管理之Gains与State测试 下篇帖子: 自动化运维工具之SaltStack-2、SaltStack配置管理
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表