自动化运维工具之SaltStack简介与安装
1、SaltStack简介
官方网址:http://www.saltstack.com
官方文档:http://docs.saltstack.com
GitHub:https:github.com/saltstack
SaltStack是一个服务器基础架构集中化管理平台,具备配置管理、远程执行、
监控等功能,一般可以理解为简化版的puppet和加强版的func。SaltStack基于
Python语言实现,结合轻量级消息队列(ZeroMQ)与Python第三方模块
(Pyzmq、PyCrypto、Pyjinjia2、python-msgpack和PyYAML等)构建。
通过部署SaltStack环境,我们可以在成千上万台服务器上做到批量执行命令,
根据不同业务特性进行配置集中化管理、分发文件、采集服务器数据、操作系统基
础及软件包管理等,SaltStack是运维人员提高工作效率、规范业务配置与操作的利
器。
2、SaltStack特性
(1)、部署简单、方便;
(2)、支持大部分UNIX/Linux及Windows环境;
(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系统
# cat /etc/redhat-release
CentOS Linux release 7.2. (Core) # uname -r
3.10.-.el7.x86_64 # hostname -I
192.168.1.12 # hostname -I
192.168.1.100
2、操作系统基础优化
参考博客:http://blog.51cto.com/12217917/2060136
5、yum安装SaltStack
# rpm -ivh https://repo.saltstack.com/yum/redhat/salt-repo-latest-2.el7.noarch.rpm #两台服务器都安装rpm包
1、salt管理节点安装
# yum install -y salt-master salt-minion
2、salt所有客户端安装(被管理的机器)
# yum install -y salt-minion
6、启动Salt
1、管理端启动命令
# systemctl start salt-master #master端启动命令
# tree /etc/salt/pki #启动后查看目录结构
pki
└── master
├── master.pem #salt-master的公钥
├── master.pub #salt-master的私钥
├── minions
├── minions_autosign
├── minions_denied
├── minions_pre
└── minions_rejected
2、配置客户端并启动客户端
# sed -n '16p' /etc/salt/minion #修改所有客户端的配置文件
master: 192.168.56.11 #告诉客户端 salt-master是谁,:冒号后面需要有空格
注:minion配置文件的关于ID配置,{如果配置ID则使用配置里的ID作为主机通讯标记,如果不配置ID则默认以主机名作为ID为主机通讯标记(本人生产上的主机名都做修改所以这里没有配置ID),ID如果修改,需要删除之前认证的KEY,然后重新添加KEY。}
# systemctl start salt-minion #启动客户端
注:修改客户端通讯ID的步骤{.停止需要修改ID的salt-minion .salt-key 删除老的id .删除minion端的/etc/salt/minion_id .删除minion端/etc/salt/pki .修改minion配置文件的id .启动minion .master端重新salt-key加入} # tree #启动后查看客户端的结构
.
├── minion
├── minion.d
├── minion_id
└── pki
└── minion
├── minion.pem #minion的公钥
└── minion.pub #minion的私钥
7、在master端添加客户端
说明:这一步操作就相当与签劳动合同,表示客户端(salt-minion)接受server端(salt-master)管理。
# salt-key #查看客户端的命令
Accepted Keys: #已经同意的key有哪些
Denied Keys: #拒绝的key有哪些
Unaccepted Keys: #未同意的key有哪些
linux-node1 #客户端的通讯ID(由于前面没有配置,这里以主机名的形式出现)
linux-node2 #客户端的通讯ID(由于前面没有配置,这里以主机名的形式出现) # salt-key -A #-A表示同意所有的客户端通讯ID
The following keys are going to be accepted:
Unaccepted Keys:
db02-
saltstack-
Proceed? [n/Y] y #确认信息,是否同意这两个key
Key for minion linux-node1
Key for minion linux-node2 关于salt-key的参数
-d 删除单个key,也支持*号模糊匹配删除 (针对key的操作)
-D 删除所有key,慎用 (针对key的操作)
-L 列表 (远程执行、列表key等)
-A 同意所有key (针对key的操作)
-a 同意单个,可以用*号迷糊匹配添加 (针对key的操作)
-G 匹配Grains (远程执行)
-I 匹配Pillar (远程执行)
-E 支持正则表达式 (远程执行)
-S 指定客户端的ip地址 (远程执行)
-C 一条远程执行的命令同时支持多个参数 (远程执行)
-N 支持节点组 (远程执行)
更多操作请通过salt-key --help来查看
8、master端确认是否能连接到客户端(salt-minion端)
1、测试所有客户端是否能通讯
# salt '*' test.ping #{*为通配符,表示所有。test为模块,ping为test模块下的一个方法(测试是否能通讯)}
linux-node2
True #True为通,False为失败
linux-node1
True
2、远程执行shell命令
# salt ' linux-node2 ' cmd.run "w" #单独指定某个客户端的通讯ID表示在这台客户端执行(cmd.cun表示执行shell命令,支持linux下所有的shell命令)
linux-node2:
:: up :, user, load average: 0.00, 0.01, 0.05
如有问题欢迎指出与交流。
自动化运维工具之SaltStack简介与安装的更多相关文章
- 自动化运维工具之 Ansible 介绍及安装使用
一.初识Ansible 介绍: Absible 使用 模块(Modules)来定义配置任务.模块可以用标准脚本语言(Python,Bash,Ruby,等等)编写,这是一个很好的做法,使每个模块幂等.A ...
- linux自动化运维工具Ansible saltstack Puppet、Chef、Fabric之间的对比
发现分布式是一个发展的趋势,无论是大型网站的负载均衡架构还是大数据框架部署,以及云存储计算系统搭建都离不开多台服务器的连续部署和环境搭建. 当我们的基础架构是分散式或者基于云的,并且我们经常需要处理在 ...
- Ansible自动化运维工具
ansible软件介绍 python语言是运维人员必会的语言! ansible是一个基于Python开发的自动化运维工具!(saltstack) 其功能实现基于SSH远程连接服务! ans ...
- 自动化运维工具 SaltStack 搭建
原文地址:https://www.ibm.com/developerworks/cn/opensource/os-devops-saltstack-in-cloud/index.html#N10072 ...
- 自动化运维工具SaltStack详细部署
==========================================================================================一.基础介绍==== ...
- 自动化运维工具SaltStack详细部署【转】
==========================================================================================一.基础介绍==== ...
- CheungSSH国产自动化运维工具开源Web界面
CheungSSH web2.0 发布文档 CheungSSH 简介 CheungSSH是一款国人自主研发的Linux运维自动化管理服务器软件,秉着为企业降低运营成本,解放管理员双手和自动化生产的理念 ...
- 自动化运维工具Ansible详细部署 (转载)
自动化运维工具Ansible详细部署 标签:ansible 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://sofar.blog. ...
- 企业级自动化运维工具应用实战-ansible
背景 公司计划在年底做一次大型市场促销活动,全面冲刺下交易额,为明年的上市做准备.公司要求各业务组对年底大促做准备,运维部要求所有业务容量进行三倍的扩容,并搭建出多套环境可以共开发和测试人员做测试,运 ...
随机推荐
- python开发笔记-ndarray方法属性详解
Python中的数组ndarray是什么? 1.NumPy中基本的数据结构 2.所有元素是同一种类型 3.别名是array 4.利于节省内存和提高CPU计算时间 5.有丰富的函数 ndarray的创建 ...
- Non-boring sequences(启发式分治)
题意:一个序列被称作是不无聊的,当且仅当,任意一个连续子区间,存在一个数字只出现了一次,问给定序列是否是不无聊的. 思路:每次找到一个只出现了一次的点,其位置的pos,那么继续分治[L,pos-1], ...
- 06-Flutter移动电商实战-dio基础_Get_Post请求和动态组件协作
上篇文章中,我们只看到了 dio 的使用方式,但并未跟应用关联起来,所以这一篇将 dio 网络请求与应用界面结合起来,当然这也是为以后的实战作基础准备,基础打牢,我们才能飞速前进. 1.案例说明 我们 ...
- L1219
八皇后问题. 然而重点在于判断斜线attack问题和 剪枝问题, 不过判断斜线这些东西都挺有意思的. 是坐标的思想但是 有不一样, 因为这个棋盘.. 斜线判断是可以理解了. 但是我想知道的是这个的原理 ...
- know thself
- rust cargo 一些方便的三方cargo 子命令扩展
内容来自cargo 的github wiki,记录下,方便使用 可选的列表 cargo-audit - Audit Cargo.lock for crates with security vulner ...
- C博客作业01--分支丶顺序结构
1.本章学习总结 1.1学习内容总结 分支结构 if else-if语句与switch语句都具有选择判断的功能,但是在使用时又有所区别,按题目的不同要求与题意选择不同语句. if else-if语句表 ...
- vsftp 匿名访问设置设置
本文通过MetaWeblog自动发布,原文及更新链接:https://extendswind.top/posts/technical/vsftpd_configuration vsftpd (very ...
- linux修改固定IP
点击虚拟机菜单栏的编辑,选择虚拟网络编辑器 选择Vmnet8 NAT模式,查看子网ip:192.168.233.0 我们的虚拟机网络模式也需要选择NAT模式 打开虚拟机,输入:ip addr 查看当前 ...
- Cobaltstrike与Metasploit会话转换
这里只做记录,不做详解 0x00 实验环境 被控制机:192.168.126.129 Metasploit:192.168.126.128 Cobaltstrike:182...* 0x01 CS会话 ...