1、SaltStack简介

官方网址:http://www.saltstack.com
官方文档:http://docs.saltstack.com
GitHubhttps:github.com/saltstack

SaltStack是一个服务器基础架构集中化管理平台,具备配置管理、远程执行、
监控等功能,一般可以理解为简化版的puppet和加强版的func。SaltStack基于
Python语言实现,结合轻量级消息队列(ZeroMQ)与Python第三方模块
(Pyzmq、PyCrypto、Pyjinjia2、python-msgpack和PyYAML等)构建。
通过部署SaltStack环境,我们可以在成千上万台服务器上做到批量执行命令,
根据不同业务特性进行配置集中化管理、分发文件、采集服务器数据、操作系统基
础及软件包管理等,SaltStack是运维人员提高工作效率、规范业务配置与操作的利
器。

2、SaltStack特性

(1)、部署简单、方便;
(2)、支持大部分UNIX/LinuxWindows环境;
(3)、主从集中化管理;
(4)、配置简单、功能强大、扩展性强;
(5)、主控端(master)和被控端(minion)基于证书认证,安全可靠;

(6)、支持API及自定义模块,可通过Python轻松扩展。

3、SaltStack的结构

saltstack采用C/S(客户端和server端)架构,salt-master为server端,salt-minion为客户端

a)Master与Minion认证

(1)、minion在第一次启动时,会在/etc/salt/pki/minion/(该路径在/etc/salt/minion里面设置)下自动生成minion.pem(private key)和 minion.pub(public key),然后将 minion.pub发送给master。

(2)、master在接收到minion的public key后,通过salt-key命令accept minion public key,这样在master的/etc/salt/pki/master/minions下的将会存放以minion id命名的 public key,然后master就能对minion发送指令了。

b)Master与minion链接

(1)、SaltStack master启动后默认监听4505和4506两个端口。4505(publish_port)为saltstack的消息发布系统,4506(ret_port)为saltstack客户端与服务端通信的端口。如果使用lsof 查看4505端口,会发现所有的minion在4505端口持续保持在ESTABLISHED状态。

4、SaltStack基础安装与操作

(1)环境说明

192.168.1.12 安装salt-master salt-minion
192.168.1.100 安装salt-minion

1、本次操作采用CentOS 7.2系统

  1. # cat /etc/redhat-release
  2. CentOS Linux release 7.2. (Core)
  3.  
  4. # uname -r
  5. 3.10.-.el7.x86_64
  6.  
  7. # hostname -I
  8. 192.168.1.12
  9.  
  10. # hostname -I
  11. 192.168.1.100

2、操作系统基础优化

参考博客:http://blog.51cto.com/12217917/2060136

5、yum安装SaltStack

  1. # rpm -ivh https://repo.saltstack.com/yum/redhat/salt-repo-latest-2.el7.noarch.rpm #两台服务器都安装rpm包

1、salt管理节点安装

  1. # yum install -y salt-master salt-minion

2、salt所有客户端安装(被管理的机器)

  1. # yum install -y salt-minion

6、启动Salt

1、管理端启动命令

  1. # systemctl start salt-master #master端启动命令
  2. # tree /etc/salt/pki #启动后查看目录结构
  3. pki
  4. └── master
  5. ├── master.pem #salt-master的公钥
  6. ├── master.pub #salt-master的私钥
  7. ├── minions
  8. ├── minions_autosign
  9. ├── minions_denied
  10. ├── minions_pre
  11. └── minions_rejected

2、配置客户端并启动客户端

  1. # sed -n '16p' /etc/salt/minion #修改所有客户端的配置文件
  2. master: 192.168.56.11 #告诉客户端 salt-master是谁,:冒号后面需要有空格
  3. 注:minion配置文件的关于ID配置,{如果配置ID则使用配置里的ID作为主机通讯标记,如果不配置ID则默认以主机名作为ID为主机通讯标记(本人生产上的主机名都做修改所以这里没有配置ID),ID如果修改,需要删除之前认证的KEY,然后重新添加KEY。}
  4. # systemctl start salt-minion #启动客户端
  5. 注:修改客户端通讯ID的步骤{.停止需要修改IDsalt-minion .salt-key 删除老的id .删除minion端的/etc/salt/minion_id .删除minion端/etc/salt/pki .修改minion配置文件的id .启动minion .master端重新salt-key加入}
  6.  
  7. # tree #启动后查看客户端的结构
  8. .
  9. ├── minion
  10. ├── minion.d
  11. ├── minion_id
  12. └── pki
  13. └── minion
  14. ├── minion.pem #minion的公钥
  15. └── minion.pub #minion的私钥

7、在master端添加客户端

说明:这一步操作就相当与签劳动合同,表示客户端(salt-minion)接受server端(salt-master)管理。

  1. # salt-key #查看客户端的命令
  2. Accepted Keys: #已经同意的key有哪些
  3. Denied Keys: #拒绝的key有哪些
  4. Unaccepted Keys: #未同意的key有哪些
  5. linux-node1 #客户端的通讯ID(由于前面没有配置,这里以主机名的形式出现)
  6. linux-node2 #客户端的通讯ID(由于前面没有配置,这里以主机名的形式出现)
  7.  
  8. # salt-key -A #-A表示同意所有的客户端通讯ID
  9. The following keys are going to be accepted:
  10. Unaccepted Keys:
  11. db02-
  12. saltstack-
  13. Proceed? [n/Y] y #确认信息,是否同意这两个key
  14. Key for minion linux-node1
  15. Key for minion linux-node2
  16.  
  17. 关于salt-key的参数
  18. -d 删除单个key,也支持*号模糊匹配删除 (针对key的操作)
  19. -D 删除所有key,慎用 (针对key的操作)
  20. -L 列表 (远程执行、列表key等)
  21. -A 同意所有key (针对key的操作)
  22. -a 同意单个,可以用*号迷糊匹配添加 (针对key的操作)
  23. -G 匹配Grains (远程执行)
  24. -I 匹配Pillar (远程执行)
  25. -E 支持正则表达式 (远程执行)
  26. -S 指定客户端的ip地址 (远程执行)
  27. -C 一条远程执行的命令同时支持多个参数 (远程执行)
  28. -N 支持节点组 (远程执行)
  29. 更多操作请通过salt-key --help来查看

8、master端确认是否能连接到客户端(salt-minion端)

1、测试所有客户端是否能通讯

  1. # salt '*' test.ping #{*为通配符,表示所有。test为模块,ping为test模块下的一个方法(测试是否能通讯)}
  2. linux-node2
  3. True #True为通,False为失败
  4. linux-node1
  5. True

2、远程执行shell命令

  1. # salt ' linux-node2 ' cmd.run "w" #单独指定某个客户端的通讯ID表示在这台客户端执行(cmd.cun表示执行shell命令,支持linux下所有的shell命令)
  2. linux-node2:
  3. :: up :, user, load average: 0.00, 0.01, 0.05

如有问题欢迎指出与交流。

自动化运维工具之SaltStack简介与安装的更多相关文章

  1. 自动化运维工具之 Ansible 介绍及安装使用

    一.初识Ansible 介绍: Absible 使用 模块(Modules)来定义配置任务.模块可以用标准脚本语言(Python,Bash,Ruby,等等)编写,这是一个很好的做法,使每个模块幂等.A ...

  2. linux自动化运维工具Ansible saltstack Puppet、Chef、Fabric之间的对比

    发现分布式是一个发展的趋势,无论是大型网站的负载均衡架构还是大数据框架部署,以及云存储计算系统搭建都离不开多台服务器的连续部署和环境搭建. 当我们的基础架构是分散式或者基于云的,并且我们经常需要处理在 ...

  3. Ansible自动化运维工具

    ansible软件介绍 python语言是运维人员必会的语言!  ansible是一个基于Python开发的自动化运维工具!(saltstack)  其功能实现基于SSH远程连接服务!  ans ...

  4. 自动化运维工具 SaltStack 搭建

    原文地址:https://www.ibm.com/developerworks/cn/opensource/os-devops-saltstack-in-cloud/index.html#N10072 ...

  5. 自动化运维工具SaltStack详细部署

    ==========================================================================================一.基础介绍==== ...

  6. 自动化运维工具SaltStack详细部署【转】

    ==========================================================================================一.基础介绍==== ...

  7. CheungSSH国产自动化运维工具开源Web界面

    CheungSSH web2.0 发布文档 CheungSSH 简介 CheungSSH是一款国人自主研发的Linux运维自动化管理服务器软件,秉着为企业降低运营成本,解放管理员双手和自动化生产的理念 ...

  8. 自动化运维工具Ansible详细部署 (转载)

    自动化运维工具Ansible详细部署 标签:ansible 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://sofar.blog. ...

  9. 企业级自动化运维工具应用实战-ansible

    背景 公司计划在年底做一次大型市场促销活动,全面冲刺下交易额,为明年的上市做准备.公司要求各业务组对年底大促做准备,运维部要求所有业务容量进行三倍的扩容,并搭建出多套环境可以共开发和测试人员做测试,运 ...

随机推荐

  1. 查看mysql执行时间

    mysql的 profiling不是默认打开的 查看profiling是否找开 mysql> show variables like "%pro%"; +---------- ...

  2. 关于Java的i++和++i的区别

    之前对于 i++ 和 ++i 的理解就是: int i=1,a=0; 1.i++ 先运算在赋值,例如 a=i++,先运算a=i,后运算i=i+1,所以结果是a==1 2.++i 先赋值在运算,例如 a ...

  3. STM32L4R9使用HAL库调试IIC注意事项

    STM32使用Cubemx生成的代码中,用到IIC的驱动,但是始终不能读写,因此使用逻辑分析仪,发现原本地址为0x58的写成了0x20,因此肯定是地址错了.因此,总结如下: 1.需要逻辑分析仪分析II ...

  4. 代码中的mysql语法问题

    今天在代码中写了mysql的删除语句 String lpinsuredSQL=" delete from lpinsured a where a.insuredid='?InsuredID? ...

  5. LOJ P10004 智力大冲浪 题解

    每日一题 day37 打卡 Analysis 经典的带限期和罚款的单位时间任务调度问题 将 val 从大到小排序,优先处理罚款多的,将任务尽量安排在期限之前,并且靠后,如果找不到,则放在最后面 #in ...

  6. 纯js制作九宫格

    Demo实现了对任意方格进行拖拽,可以交换位置,其中Demo-1利用了勾股定理判断距离! Demo-1整体思路: 1.首先div实现自由移动,一定需要脱离标准文档流,所以我们给它使用绝对定位. 2.利 ...

  7. 计蒜之道 百度AI小课堂-上升子序列

    计蒜之道 百度AI小课堂-上升子序列 题目描述 给一个长度为 \(n\) 的数组 \(a\) .试将其划分为两个严格上升子序列,并使其长度差最小. 输入格式 输入包含多组数据. 数据的第一行为一个正整 ...

  8. 解决IE报错:Locale 'chinese' is not well-formed,或RangeError: 区域设置“chinese”的格式不正确的问题

    接之前的此博客问题处理:js处理时间时区问题 由于 toLocaleString():据本地时间格式,把 Date 对象转换为字符串.总是会带有上午/下午,所以我加了参数:new Date('2019 ...

  9. 怎么在app上添加图标和文字

    window.showAddMenu = this.addSearch let data = { type: 'ICON', text: 'https://static-image.lexing360 ...

  10. [开源] FreeSql.AdminLTE.Tools 根据实体类生成后台管理代码

    前言 FreeSql 发布至今已经有9个月,功能渐渐完善,自身的生态也逐步形成,早在几个月前写过一篇文章<ORM 开发环境之利器:MVC 中间件 FreeSql.AdminLTE>,您可以 ...