1. 主机规划

注意事项

修改了master或者minion的配置文件,那么必须重启对应的服务。

2. 了解YAML

具体地址

https://docs.saltstack.com/en/latest/topics/yaml/index.html    

YAML:三板斧

、缩进:  2个空格,不能使用Tab
、冒号: key: value 注意有空格
、短横线: - list1 注意有空格
- list2

3. 配置管理路径指定

3.1. master指定配置管理基本路径

 [root@salt100 salt]# pwd
/etc/salt
[root@salt100 salt]# vim master
………………
# Example:
# file_roots:
# base:
# - /srv/salt/
# dev:
# - /srv/salt/dev/services
# - /srv/salt/dev/states
# prod:
# - /srv/salt/prod/services
# - /srv/salt/prod/states
#
# 将如下的注释放开即可
# 也可以不变更配置,因为这是个默认配置★★
file_roots:
base:
- /srv/salt
………………
[root@salt100 salt]# systemctl restart salt-master.service # 修改了配置文件,必须重启服务

3.2. 创建对应的目录

[root@salt100 ~]# mkdir -p /srv/salt

4. 测试案例--单个状态管理

4.1. 编写测试案例----安装apache

1、为了方便后期维护指定一个特定目录

 [root@salt100 salt]# pwd
/srv/salt
[root@salt100 salt]# mkdir web
[root@salt100 salt]# cd web/
[root@salt100 web]# pwd
/srv/salt/web

2、编写sls文件

 [root@salt100 web]# pwd
/srv/salt/web
[root@salt100 web]# cat apache.sls # 后缀名 sls,salt执行时会找sls文件
# sls文件允许注释存在,内容可以直接复制使用
# 自定义的一个ID,唯一标识 ★★★★★
apache-install:
# pkg 是一个执行模块 . 引用 installed 使用方法
pkg.installed:
# - names 参数 支持多个列表
- names:
- httpd
- httpd-devel # enable: True 表示:开机自启动
apache-service:
service.running:
- name: httpd
- enable: True

4.2. 在master机器salt100上执行

给salt01、salt02、salt03部署安装httpd

 # 在master机器操作
[root@salt100 ~]# salt 'salt0*' test.ping # 看salt01、salt02、salt03是否可通信
salt01:
True
salt03:
True
salt02:
True
[root@salt100 ~]# salt 'salt0*' state.sls web.apache # 给 salt01、salt02、salt03 部署httpd
# 说明:
# 、master 配置管理基本目录为 /srv/salt
# 、apache.sls 的路径为:/srv/salt/web/apache.sls
# 、state.sls web.apache 说明 state模块,调用 sls方法, 调用的文件是web路径下的apache.sls文件【只是最后的 sls后缀名省略了】

备注:做了哪些事情

1、  将/srv/salt/web/apache.sls文件从master发送给minion;

2、  minion得到文件后,根据master指令执行apache.sls中的内容

master将文件发送到minion的那个位置

 # 在minion端查看
[root@salt01 salt]# pwd
/var/cache/salt
[root@salt01 salt]# ll
total
drwxr-xr-x root root Dec : minion
[root@salt01 salt]# tree
.
└── minion
├── accumulator
├── extmods
├── files
│ └── base
│ └── web
│ └── apache.sls
├── highstate.cache.p
├── proc
└── sls.p directories, files

4.3. 执行结果信息讲解

 # 执行返回结果是无序的
[root@salt100 ~]# salt 'salt0*' state.sls web.apache
salt02: # salt02执行结果信息
----------
ID: apache-install # apache.sls 中自定的ID【名称】
Function: pkg.installed
Name: httpd
Result: True
Comment: The following packages were installed/updated: httpd
Started: ::46.604986
Duration: 30335.469 ms
Changes:
----------
httpd:
----------
new:
2.4.-.el7.centos
old:
httpd-tools:
----------
new:
2.4.-.el7.centos
old:
mailcap:
----------
new:
2.1.-.el7
old:
----------
ID: apache-install
Function: pkg.installed
Name: httpd-devel
Result: True
Comment: The following packages were installed/updated: httpd-devel
Started: ::16.965844
Duration: 6661.51 ms
Changes:
----------
apr-devel:
----------
new:
1.4.-.el7_4.
old:
apr-util-devel:
----------
new:
1.5.-.el7
old:
cyrus-sasl:
----------
new:
2.1.-.el7
old:
cyrus-sasl-devel:
----------
new:
2.1.-.el7
old:
expat-devel:
----------
new:
2.1.-.el7_3
old:
httpd-devel:
----------
new:
2.4.-.el7.centos
old:
libdb-devel:
----------
new:
5.3.-.el7
old:
openldap:
----------
new:
2.4.-.el7
old:
2.4.-.el7
openldap-devel:
----------
new:
2.4.-.el7
old:
----------
ID: apache-service
Function: service.running
Name: httpd
Result: True
Comment: Service httpd has been enabled, and is running
Started: ::24.619598
Duration: 314.737 ms
Changes:
----------
httpd:
True Summary for salt02
------------
Succeeded: (changed=)
Failed:
------------
Total states run:
Total run time: 37.312 s
salt01: # salt01执行结果信息
………………
salt03: # salt03执行结果信息
----------
………………

5. Salt高级状态管理

生产环境使用,注意事项:

、执行时不能使用 '*' ,所有minion执行
、不能直接执行,要先 test=True;

5.1. 高级状态sls文件的位置和名称

默认file_roots的位置

不用修改配置文件,默认即可。

5.2. 编写top.sls文件

 [root@salt100 salt]# pwd
/srv/salt
[root@salt100 salt]# tree
.
├── top.sls
└── web
└── apache.sls directory, files
[root@salt100 salt]# cat top.sls
base:
# 使用通配符
'salt0*':
- web.apache
# - web.nginx # 可以有多个
# 指定具体minion
'salt03':
- web.apache

5.3. 执行高级状态

 [root@salt100 ~]# salt 'salt01' state.highstate test=True  # 必须先执行这个
………………
# 原因:防止自己手动改了minion机器上组件的配置信息,但是没有同步到salt;
# 结果直接执行后,又改回去了。
[root@salt100 ~]# salt 'salt01' state.highstate # 执行高级状态,通过top.sls 去查找
………………

Saltstack_使用指南03_配置管理的更多相关文章

  1. Saltstack_使用指南12_配置管理-jinja模板

    1. 说明 下文的案例是根据上一篇文章进行的修改.因此请优先读取上一章博文内容<Saltstack_使用指南11_配置管理-状态之间依赖关系> 2. 主机规划 salt 版本 [root@ ...

  2. Saltstack_使用指南11_配置管理-状态之间依赖关系

    1. 说明 下文的案例是根据上一篇文章进行的修改.因此请优先读取上一篇文章内容<Saltstack_10_配置管理-状态模块> 并且目录进行了变化,从 /srv/salt/lamp 变为了 ...

  3. Saltstack_使用指南10_配置管理-状态模块

    1. 主机规划 salt 版本 [root@salt100 ~]# salt --version salt (Oxygen) [root@salt100 ~]# salt-minion --versi ...

  4. Saltstack_使用指南17_salt-ssh

    1. 主机规划 salt 版本 [root@salt100 ~]# salt --version salt (Oxygen) [root@salt100 ~]# salt-minion --versi ...

  5. Saltstack_实战指南02_各主机Pillar信息指定

    1. 实战项目GitHub地址 该项目已经放在了GitHub上,地址如下: https://github.com/zhanglianghhh/salt-example-lnmp 2. 主机规划 3. ...

  6. Saltstack_实战指南01_系统规划

    1. 实战项目GitHub地址 之前<Saltstack_使用指南>详细讲解了saltstack的使用.那么从这节开始实战讲解,当然不会再像之前那样详细说明了.只是讲一些系统规划之类的信息 ...

  7. Saltstack_使用指南16_syndic

    1. 主机规划 salt 版本 [root@salt100 ~]# salt --version salt (Oxygen) [root@salt100 ~]# salt-minion --versi ...

  8. Saltstack_使用指南05_数据系统-Pillar

    1. 主机规划 Pillar文档 https://docs.saltstack.com/en/latest/topics/pillar/index.html 注意事项 修改了master或者minio ...

  9. Saltstack_使用指南04_数据系统-Grains

    1. 主机规划 Grains文档 https://docs.saltstack.com/en/latest/topics/grains/index.html 注意事项 修改了master或者minio ...

随机推荐

  1. 【Spark篇】---SparkStreaming+Kafka的两种模式receiver模式和Direct模式

    一.前述 SparkStreamin是流式问题的解决的代表,一般结合kafka使用,所以本文着重讲解sparkStreaming+kafka两种模式. 二.具体 1.Receiver模式    原理图 ...

  2. 10.Flask上下文

    1.1.local线程隔离对象 不用local对象的情况 from threading import Thread request = ' class MyThread(Thread): def ru ...

  3. solr之环境配置一

    安装Java JDK solr运行需要java serverlet 容器,默认使用jetty,或者tomcat,jboss等等. 下载一个jdk,我的jdk是jdk1.7.0_65. 安装JDK的步骤 ...

  4. 【朝花夕拾】Android Log篇

    前言  从事Android开发的这些年中,经常碰到这样一个现象:同一款app中,往往有好几种风格迥异的log处理方式,有时候会让维护者晕头转向.同时笔者也经常碰带一些模棱两可的问题:Log等级分好几种 ...

  5. 带着新人学springboot的应用09(springboot+异步任务)

    本来想说说检索的,不过不知道什么鬼,下载ElasticSearch太慢了,还是放一下,后面有机会再补上!今天就说个简单的东西,来说说任务. 什么叫做任务呢?其实就是类中实现了一个什么功能的方法.常见的 ...

  6. Python包的导入说明

    import 模块 from 包 import 模块 上面的代码有什么区别呢? from 模块 import * 这种导入想象与把模块里面的代码都复制到当前模块中(也就是该语句所在位置),这时候你可以 ...

  7. 使用mpvue开发小程序教程(一)

    前段时间,美团开源了mpvue这个项目,使得我们又多了一种用来开发小程序的框架选项.由于mpvue框架是完全基于Vue框架的(重写了其runtime和compiler),因此在用法上面是高度和Vue一 ...

  8. 流式大数据计算实践(6)----Storm简介&使用&安装

    一.前言 1.这一文开始进入Storm流式计算框架的学习 二.Storm简介 1.Storm与Hadoop的区别就是,Hadoop是一个离线执行的作业,执行完毕就结束了,而Storm是可以源源不断的接 ...

  9. Spring Boot 2.x(七):优雅的处理异常

    前言 异常的处理在我们的日常开发中是一个绕不过去的坎,在Spring Boot 项目中如何优雅的去处理异常,正是我们这一节课需要研究的方向. 异常的分类 在一个Spring Boot项目中,我们可以把 ...

  10. Windows 花屏问题

    已经有2台电脑 Windows 10 系统出现花屏现象,表现为比较炫的界面出现花屏.文字显示不全.移位.闪烁等,如果点击“设置”.“开始”,Chrome浏览器等:比较平素的界面显示正常,比如资源管理器 ...