设为首页 收藏本站
查看: 2232|回复: 2

[经验分享] 集中化管理平台Saltstack

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-5-26 10:48:41 | 显示全部楼层 |阅读模式
集中化管理平台Saltstack

  Saltstack是一个服务器基础架构集中化管理平台,开始于2011年的一个项目,具备配置管理、远程执行、监控等功能,一般可以理解成简化版的puppet和加强版的func。Slatstack基于Python语言实现,结合轻量级消息队列(ZeroMQ)与Python第三方模块(Pyzmq、PyCrypto、Pyjinja2、python-msgpack和PyYAML等)构建。

  关于什么是Salt,请查阅官方说明:http://docs.saltstack.cn/topics/index.html

基本原理

  SaltStack 采用 C/S模式,server端就是salt的master,client端就是minion,minion与master之间通过ZeroMQ消息队列通信。

  minion上线后先与master端联系,把自己的pub key发过去,这时master端通过salt-key -L命令就会看到minion的key,接受该minion-key后,也就是master与minion已经互信。

  master可以发送任何指令让minion执行了,salt有很多可执行模块,比如说cmd模块,在安装minion的时候已经自带了,它们通常位于你的python库中。这些模块是python写成的文件,里面会有好多函数,如cmd.run,当我们执行salt '*'cmd.run 'uptime'的时候,master下发任务匹配到的minion上去,minion执行模块函数,并返回结果。

  master监听4505和4506端口,4505对应的是ZMQ的PUB system,用来发送消息,4506对应的是REP system是来接受消息的。

我们可以这样理解:

  Salt stack的Master与Minion之间通过ZeroMq进行消息传递,使用了ZeroMq的发布-订阅模式,连接方式包括tcp,ipc。

1.发送消息:

  salt命令,将cmd.run ls命令从salt.client.LocalClientNaNd_cli发布到master,获取一个jobid,根据jobid获取命令执行结果。master接收到命令后,将要执行的命令发送给客户端minion。

2.执行命令:

  minion从消息总线上接收到要处理的命令,交给minion._handle_aes处理。minion._handle_aes发起一个本地线程调用cmdmod执行ls命令。

3.执行结果处理:

  线程执行完ls后,调用minion._return_pub方法,将执行结果通过消息总线返回给master。master接收到客户端返回的结果,调用master._handle_aes方法,将结果写在文件中。

4.返回执行结果:

  salt.client.LocalClientNaNd_cli通过轮询获取Job执行结果,将结果输出到终端。

下面,我们来部署Saltstack的平台:
一,环境配置说明1.IP地址分配Hostname     IP地址     节点
saltstack01   10.62.83.211 salt-master
Ctest01         10.62.83.11   salt-minion
2.协议和端口节点                 服务                端口号            功能
Salt-master    python2.6     4505     ZeroMQ的PUBsystem,发送消息
                      Python2.6     4506     REPsystem是来接受消息
Salt-minion     python2.6     4505    ZMQ的PUBsystem,发送消息
3.软件版本软件                 版本号
OS       CentOSrelease 6.7 (Final)
Python     python2.6.6
saltstack  2015.8.10 (Beryllium)                  
二,YUM源配置 我们采用yum的安装方式
1
2
3
4
5
6
7
8
9
# rpm --import https://repo.saltstack.com/yum/r ... ACK-GPG-KEY.pub#yum源认证文件
# vim/etc/yum.repos.d/saltstack.repo #yum源配置文件
[saltstack-repo]
name=SaltStack repo for RHEL/CentOS $releasever
baseurl=https://repo.saltstack.com/yum/redhat/$releasever/$basearch/latest
enabled=1
gpgcheck=1
gpgkey=
# yumrepolist #yum列表更新



三,安装配置主控端master1.安装salt-master
1
# yuminstall salt-master



下图是依赖包的安装:
QQ截图20160526104800.jpg
2.主控端主文件配置
1
2
3
4
5
6
7
8
9
10
# vim/etc/salt/master
interface:10.62.83.211 ##绑定Master通信IP。
auto_accept:True ##自动认证,避免手动运行salt-key来确认证书信任。
#pillar_opts:False ## 是否开启pillar
#pillar_roots:  ##这里3行是定义pillar的主目录
#  base:
#    - /srv/pillar
file_roots:   ##指定saltstack文件根目录位置
  base:
- /srv/salt



3.启动主控端服务
1
#service salt-master start




1
#chkconfig  salt-master  on #配置为开机服务自启动



4.主控端防火墙配置  在主控端添加TCP 4505,TCP4506的防火墙规则,而在被控端无须配置防火墙,原理是被控端直接与主控端的zeromq建立长链接,接收广播到的任务信息并执行。
1
2
3
# vim/etc/sysconfig/iptables
-IINPUT -m state --state new -m tcp -p tcp --dport 4505 -j ACCEPT
-IINPUT -m state --state new -m tcp -p tcp --dport 4506 -j ACCEPT



QQ截图20160526104809.jpg
四,安装被控端minion1.安装salt-minion
1
# yuminstall salt-minion –y



2.被控端主文件配置
1
2
3
# vim/etc/salt/minion
master:10.62.83.211
id:Ctest01 ##修改被控端主机识别id,建议使用操作系统主机名来配置



  注意:
  如果环境中没有域名解析服务,我们可以配置/etc/hosts文件实现自解析域名。
3.启动被控端服务#service salt-minion start

1
#chkconfig  salt-minion  on ##配置为开机服务自启动



4. 开放被控端防火墙端口
1
2
# vim/etc/sysconfig/iptables
-IINPUT -m state --state new -m tcp -p tcp --dport 4505 -j ACCEPT



五,结果测试验证测试结果 QQ截图20160526104818.jpg
思考:    生产环境中,成千上万台host,我们怎么批量部署被控端呢?哈哈,salt-ssh可以解决。


运维网声明 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-222097-1-1.html 上篇帖子: 使用Salt-ssh部署Salt-minion之yum安装 下篇帖子: 运维自动化之centos6.5 yum安装salt
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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