一,YAML语法

  首先先了解一下YAML,默认的SLS文件的renderer是YAML renderer。YAML是一个有很多强大特性的标记性语言。Salt使用了一个YAML的小型子集,映射非常常用的数据结构,像列表和字典。YAML renderer的工作是将YAML数据格式的结构编译成为Python数据结构给Salt使用。

  YAML语法有三个注意事项,具体如下:

  1,使用空白字符为文件缩排表示结构,不过不能使用TAB

  2,注释用#号

  3,字符串平常不使用引号,如果有需要,可以使用单引号或双引号。使用双引号表示字符串时,特殊字符可以通过倒斜线(\)来进行定义

具体用法

 1,列表:短杠(-)+ 空白字符
- henry
- sina
等价于:['henry','sina']
,字典:key和value通过冒号(:)+空白字符隔开
name: henry
site: http://www.saltstack.cn/
等价于:{'name':'henry','site':'http://www.saltstack.cn/'}
,多层结构:通过缩进来表示层级
- henry:
- sites:
- blog: http://www.saltstack.cn/
等价于:[{'henry':[{'sites':[{'blog':'http://www.saltstack.cn/'}]}]}]

官网地址:http://docs.saltstack.cn/topics/yaml/index.html

二,jinja

  Salt默认使用Jinja2模板系统来生成YAML,是python语言开发的一个模板引擎,类似于Djingo模板系统

jinja模块的用法:

 变量:{{ foo }},变量如果是字典的话可以使用{{foo.bar}}或{{foo['bar']}}
注释:{# comment #}
for:                          ##可以使用for循环取值
{% for eachitem in items %}
{{ eachitem }}
{% endfor %}
if:                           ##可以做if条件判断
{% if GFW %}
welcome to China!
{% elif not Internet %}
welcome to North korea!
{% else %}
Freedom
{% endif %}

三,State Tree

  Top file:配置管理入口文件,和pillar类似,指定minions需要完成那些配置管理,默认为top.sls
  注:在定义top.sls时,会先找apache/init.sls,如果没有的话,会找apache.sls
  base:
    '*':
      - apache
  sls模块使用点(.)来分割,如apache.install等于salt://apache/install.sls或salt://apache/install/init.sls
  Include/Extend:sls文件间可以通过include及extend来引用和扩展
  sls中ID必须唯一,且在该ID下的同一类的状态管理模块只能有一个,所谓的slsID 就是定义sls文件时最开始定义在开头的名字。
  0.17.0 salt增加了state_auto_order参数(默认值为True),使state在没有Requisites的情况下按照从上而下的顺序进行执行

四,Requisites(相当于sls流程控制,那个先执行,那个后执行等) 

  require:本state执行时需要先执行那些state
  require_in:与require位置相反
  watch:除了require外,也会监测依赖的state的状态,如果状态发生变化,做出反应(例如监控文件变化,发生变化后立即重启服务)
  watch_in: 与watch位置相反
  prereq:0.16.0 新增的功能,会通过test=True接口检查所依赖的state的状态,如果状态发生变化,执行
  prereq_in:相反

五,下面介绍三个模块的用法,更多模块用法请参考官网

 官网地址:https://docs.saltstack.com/en/latest/ref/states/all/

 软件包状态管理模块
 模块名:pkg
 功能:管理软件包状态,会根据操作系统不同,选择对应安装方式
 基本操作:

pkg.installed:     #确保软件包已安装,如果没有安装进行安装
pkg.latest: #确保软件包是最新版本,如果不是,进行升级
pkg.remove: #确保软件包已卸载,如果之前已安装,进行卸载
pkg.purge: #除remove外,也会删除其配置文件

 文件状态管理模块:
  模块名:file
  功能:管理文件状态
  基本用法:

file.managed:     #保证文件存在并且为对应的状态
file.recurse:    #保证目录存在并且为对应的状态
file.absent:    #确保文件不存在,如果存在则进行删除操作

  服务状态管理模块:
  模块名:service
  功能: 管理服务状态
  基本用法:

service.running        #确保服务处于运行状态
service.enabled #确保服务会开机自动启动
service.disabled #确保服务不会开机自启动
service.dead #确保服务当前没有运行

六,实例操作

(一)、安装apache

top.sls
base:
'*':
- apache
init.sls apache:                    ##slsID
pkg.installed: ##安装httpd
- name: httpd
file.managed:
- name: /etc/httpd/conf/httpd.conf ##拷贝/srv/salt/apache/httpd.conf到minion的/etc/httpd/conf/httpd.conf
- source: salt://apache/httpd.conf
- require:       ##检查apache有没有安装成功
- pkg: apache
service.running:
- enable: True
- name: httpd
- watch:        ##watch检测配置文件,如果发生变化会重启服务
- pkg: apache
- file: apache

运行配置管理:salt '*' state.sls apache
salt '*' salt.highstate test=True #test=True用于测试语法

   (二)、apache需要监控8080端口,代码如下:

首先修改apache的主配置文件,修改配置文件为 listen {{ port }},修改完成后可以直接在sls文件里定义
apache:
pkg.installed:
- name: httpd
file.managed:
- name: /etc/httpd/conf/httpd.conf
- source: salt://apache/httpd.conf
- require:
- pkg: apache
- template: jinja ##调用jinja模板渲染
- context:   ##这里可以是context或default效果一样
port:
service.running:
- enable: True
- name: httpd
- watch:
- pkg: apache
- file: apache
如果多台主机监听的端口不一样,具体修改如下:
apache:
pkg.installed:
- name: httpd
file.managed:
- name: /etc/httpd/conf/httpd.conf
- source: salt://apache/httpd.conf
- require:
- pkg: apache
- template: jinja
- defaults:
{% if grains.id == "10.13.41.80" %}
port:
{% elif grais.id == "10.13.41.81" %}
port:
{% else %}
port:
{% endif %}
service.running:
- enable: True
- name: httpd
- watch:
- pkg: apache
- file: apache

为了让sls文件不参杂业务数据,业务数据应该独立存放,到了该pillar登台的时候了。

/srv/pillar/apache/init.sls
apache:
{% if grains.id == "test" %}
port:
{% elif grains.id == "test1" %}
port:
{% else %}
port:
{% endif %}
/srv/pillar/top.sls
base:
'*':
- apache salt '*' saltutil.regresh_pillar ##刷新pillar
salt '*' pillar.get apache:port ##取minion的pillar信息 /srv/salt/apache/deploy.sls
- template: jinja
- defaults:
port:{{salt['pillar.get']('apaceh:port',)}}

saltstack的状态管理state就介绍到这里。

saltstack(五) saltstack的state状态管理的更多相关文章

  1. Spark Streaming揭秘 Day14 State状态管理

    Spark Streaming揭秘 Day14 State状态管理 今天让我们进入下SparkStreaming的一个非常好用的功能,也就State相关的操作.State是SparkStreaming ...

  2. 开启 J2EE(五)— Servlet之状态管理

    HTTP无状态协议 首先我们要知道: HTTP协议是无状态协议. 我们知道HTTP协议就是server通过Request从浏览器接收和Response向浏览器输出的这么一个过程(浏览器和server的 ...

  3. 为了弄懂Flutter的状态管理, 我用10种方法改造了counter app

    为了弄懂Flutter的状态管理, 我用10种方法改造了counter app 本文通过改造flutter的counter app, 展示不同的状态管理方法的用法. 可以直接去demo地址看代码: h ...

  4. 通过Dapr实现一个简单的基于.net的微服务电商系统(五)——一步一步教你如何撸Dapr之状态管理

    状态管理和上一章的订阅发布都算是Dapr相较于其他服务网格框架来讲提供的比较特异性的内容,今天我们来讲讲状态管理. 目录:一.通过Dapr实现一个简单的基于.net的微服务电商系统 二.通过Dapr实 ...

  5. vuex状态管理,state,getters,mutations,actons的简单使用(一)

    之前的文章中讲过,组件之间的通讯我们可以用$children.$parent.$refs.props.data... 但问题来了,假如项目特别大,组件之间的通讯可能会变得十分复杂... 这个时候了我们 ...

  6. react初探(一)之JSX、状态(state)管理、条件渲染、事件处理

    前言: 最近收到组长通知我们项目组后面新开的项目准备统一技术栈为react,目前我的情况是三大框架只会angular和Vue.在实际项目中只使用过一次angular5,其余项目都是使用Vue写的.写篇 ...

  7. State management(状态管理)

    State management https://en.wikipedia.org/wiki/State_management UI控件的状态管理, 例如按钮的灰化.只读.显示隐藏等. 特殊地一个控件 ...

  8. 五、vue状态管理模式vuex

    一.vuex介绍 Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化. 即data中属性同时有一 ...

  9. 组件之间的通讯:vuex状态管理,state,getters,mutations,actons的简单使用(一)

    之前的文章中讲过,组件之间的通讯我们可以用$children.$parent.$refs.props.data... 但问题来了,假如项目特别大,组件之间的通讯可能会变得十分复杂... 这个时候了我们 ...

随机推荐

  1. Python---NumPy模块---矩阵操作

    1.NumPy访问[数组&矩阵] 2.矩阵的运算 3.NumPy通用函数 4.NumPy矩阵的合并和分割 print "**********Numpy访问(数组&矩阵)*** ...

  2. 在Linux环境下使用OpenSSL对消息和文件进行加密(转载)

    转自:http://netsecurity.51cto.com/art/201301/378513.htm 1.简介 OpenSSL是一款功能强大的加密工具包.我们当中许多人已经在使用OpenSSL, ...

  3. MyBatis基本应用

    框架的概念: 框架(Framework)是一个提供了可重用的公共结构的半成品. 数据持久化: 数据持久化是将内存中的数据模型转换为存储模型,以及将存储模型转换为内存中的数据模型的统称. ORM(Obj ...

  4. Lightoj 1010 - Knights in Chessboard (胡搞)

    题目连接: http://www.lightoj.com/volume_showproblem.php?problem=1010 题目描述: 有一个n*m的棋盘,根据象棋中马走日字的规则,问此棋盘最多 ...

  5. 2017西安网络赛B_Coin

    样例输入 2 2 1 1 3 1 2 样例输出 500000004 555555560 思路: n重伯努利实验概率分布题. 设q=1-p,p为事件概率. Y为出现偶数次的概率. 所以  Y=1/2*( ...

  6. python程序展现图片遇到的坑

    使用cv2展示图片的时候遇到了问题,提示:TypeError: Required argument 'mat' (pos 2) not found 给定的图片路径是没得问题的,代码如下: 使用open ...

  7. 基本的查询流【MSSQL】

    4个DML(Data Manipulation Language)命令 SELECT INSERT UPDATE DELETE 查询语法有一个特有的固定顺序 SELECT - FROM - WHERE ...

  8. 浅谈.net remoting 与 webservice

    1. .NET Remoting .NET Remoting是微软随.NET推出的一种分布式应用解决方案,被誉为管理应用程序域之间的 RPC 的首选技,它允许不同应用程序域之间进行通信(这里的通信可以 ...

  9. [ NOI 2002 ] Robot

    \(\\\) Description \(\\\) Solution 垃圾语文题毁我青春 这题其实就是重定义了俩函数.... 首先 \(\varphi(1)=0\) . 然后 \(2\) 在计算 \( ...

  10. [ Nowcoder Contest 175 #B ] 区间

    \(\\\) \(Description\) 给出一个长度为\(N\)的序列\(A[1]...A[N]\),定义一个合法区间 \([L,R]\) 当且仅当区间\(GCD\) 在这个区间内,求最长合法区 ...