? ?
? ?
转载自: 来自: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是来接受消息的。
具体步骤如下
安装:
配置: 通常学习环境,master用默认配置就好,修改Minion配置文件/etc/salt/minion
master: master_ip或master_FQDN ? ? ##注明master的ip或者域名
id: minion_id ? ? ? ? ? ? ? ? ? ? ?##取一个独一无二的minion名字,以方便辨认
启动:
service salt-master start
service salt-minion start
master接受minion的key:
salt-key -L ##查看所有minion_key
salt-key -a ‘key-name‘
##接受该key
或者salt-key -A ? ? ? ?##接受所有key
测试:
salt ‘*‘ test.ping ? ##查看在线minion
?salt ‘*‘ pkg.install ftp ?##所有Minion安装ftp
说明:
帮助: salt ‘‘ sys.doc ##查看所有执行模块的doc salt ‘‘ sys.doc test ##查看test模块的帮助 salt ‘*‘ sys.doc test.ping ##查看test.ping函数的帮助
执行命令:
salt ‘*‘ cmd.run ‘uptime‘ ?##在所有机器上执行命令uptime
salt ‘*‘ cmd.run ‘--reboot--‘ ?##这类命令很危险,请不要尝试,请想办法禁止
? ?
来自 <http://m.blog.csdn.net/article/details?id=50853559>
原文:http://www.cnblogs.com/iiiiher/p/5958024.html