saltstack 基本原理和基本配置
来源:互联网 发布:潮流网络 编辑:程序博客网 时间:2024/06/07 12:52
转载自: 来自:http://tech.mainwise.cn/?p=438
说明:salt是一个异构平台基础设置管理工具(虽然我们通常只用在Linux上),使用轻量级的通讯器ZMQ,用Python写成的批量管理工具,完全开源,遵守Apache2协议,与Puppet,Chef功能类似,有一个强大的远程执行命令引擎,也有一个强大的配置管理系统,通常叫做Salt State System。
基本原理:
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库中,locate salt | grep /usr/
可以看到salt自带的所有东西。
这些模块是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
salt命令,将
cmd.run ls
命令从salt.client.LocalClient.cmd_cli
发布到master,获取一个Jodid,根据jobid获取命令执行结果。master接收到命令后,将要执行的命令发送给客户端minion。
minion从消息总线上接收到要处理的命令,交给
minion._handle_aes
处理minion._handle_aes
发起一个本地线程调用cmdmod执行ls命令。线程执行完ls后,调用minion._return_pub
方法,将执行结果通过消息总线返回给mastermaster接收到客户端返回的结果,调用
master._handle_aes
方法,将结果写的文件中salt.client.LocalClient.cmd_cli
通过轮询获取Job执行结果,将结果输出到终端。
安装:
安装epel源
#For RHEL 5:rpm -Uvh http://mirror.pnl.gov/epel/5/i386/epel-release-5-4.noarch.rpm#For RHEL 6:rpm -Uvh http://ftp.linux.ncsu.edu/pub/epel/6/i386/epel-release-6-8.noarch.rpm
安装salt-master端,也就是服务端
yum -y install salt-master
安装salt-minion端,也就是client端
yum -y install salt-minion
配置: 通常学习环境,master用默认配置就好,修改Minion配置文件/etc/salt/minion
master: master_ip或master_FQDN ##注明master的ip或者域名id: minion_id ##取一个独一无二的minion名字,以方便辨认
启动:
service salt-master startservice salt-minion start
master接受minion的key:
salt-key -L ##查看所有minion_keysalt-key -a 'key-name' ##接受该key或者salt-key -A ##接受所有key
测试:
salt '*' test.ping ##查看在线minion salt '*' pkg.install ftp ##所有Minion安装ftp
说明:
- ‘*’ 代表的是target是指在那些minion上操作
- ‘test’ ,’pkg’是一个执行模块,所有的执行模块见http://docs.saltstack.com/ref/modules/all/index.html?highlight=full%20list%20builtin
- ‘ping’,’install’是执行模块下面的函数,同样参加上述链接查看帮助
- ‘ftp’ 是函数的参数(arg),有的函数需要参数,有的不需要
帮助: salt ‘‘ sys.doc ##查看所有执行模块的doc salt ‘‘ sys.doc test ##查看test模块的帮助 salt ‘*’ sys.doc test.ping ##查看test.ping函数的帮助
执行命令:
salt '*' cmd.run 'uptime' ##在所有机器上执行命令uptimesalt '*' cmd.run '--reboot--' ##这类命令很危险,请不要尝试,请想办法禁止
- saltstack 基本原理和基本配置
- 关于saltstack简介,安装和基本配置
- 安装和配置saltstack
- saltstack学习-基本介绍和安装
- saltstack配置
- Saltstack安装和基础配置官方文档
- 系统自动化配置和管理工具:SaltStack
- saltstack配置安装和windowns应用
- saltstack的简单安装和配置
- saltstack mutilmaster的具体配置和实现
- Saltstack-01基本命令
- 购物车基本原理和基本代码
- hdfs的基本原理和基本操作总结
- saltstack的安装配置
- saltstack安装配置笔记
- saltstack安装配置
- SaltStack安装及配置
- saltstack master 配置
- bzoj2127 happiness 最小割
- 学好C语言,走遍宇宙都不怕
- java中怎样表示一个无穷大? 无穷小?
- 第三方类库下载网址
- 设置TableView的行不允许被选中
- saltstack 基本原理和基本配置
- java 反射机制
- 华为oj 进制转换&&质数因子
- MySQL语句总结2
- HDU 1004:Let the Balloon Rise【STl】
- 修改整个Tableview的背景色
- 欢迎使用CSDN-markdown编辑器
- Android开发学习之路--RxAndroid之lambda
- 蓝桥杯--2012--取球游戏