设为首页 收藏本站
查看: 771|回复: 0

[经验分享] saltstack (1) 简介

[复制链接]

尚未签到

发表于 2018-7-31 10:56:59 | 显示全部楼层 |阅读模式
  基本原理:
  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是来接受消息的。
  具体步骤如下
  1. Salt stack的Master与Minion之间通过ZeroMq进行消息传递,使用了ZeroMq的发布-订阅模式,连接方式包括tcp,ipc
  2. salt命令,将cmd.run ls命令从salt.client.LocalClient.cmd_cli发布到master,获取一个Jodid,根据jobid获取命令执行结果。
  3. master接收到命令后,将要执行的命令发送给客户端minion。
  4. minion从消息总线上接收到要处理的命令,交给minion._handle_aes处理
  5. minion._handle_aes发起一个本地线程调用cmdmod执行ls命令。线程执行完ls后,调用minion._return_pub方法,将执行结果通过消息总线返回给master
  6. master接收到客户端返回的结果,调用master._handle_aes方法,将结果写的文件中
  7. salt.client.LocalClient.cmd_cli通过轮询获取Job执行结果,将结果输出到终端
  
  安装 saltstack
  [root@redis01-jp ~]#  wget https://repo.saltstack.com/yum/amazon/salt-amzn-repo-2016.11-1.amzn1.noarch.rpm
  [root@redis01-jp ~]# rpm -ivh salt-amzn-repo-2016.11-1.amzn1.noarch.rpm
  Preparing...                          ################################# [100%]
  Updating / installing...
  1:salt-amzn-repo-2016.11-1.amzn1   ################################# [100%]
  [root@redis01-jp ~]# yum install salt-master -y #服务端
  [root@redis01-jp ~]# yum install salt-minion -y #客户端
  [root@redis01-jp ~]# yum install salt-ssh
  [root@redis01-jp ~]# yum install salt-syndic
  [root@redis01-jp ~]# yum install salt-cloud
  [root@redis01-jp ~]# vim /etc/salt/master
  [root@redis01-jp ~]# sed -n '15p' /etc/salt/master
  interface: 0.0.0.0
  [root@redis01-jp ~]# service salt-master start
  Starting salt-master daemon:                               [  OK  ]
  [root@redis01-jp ~]# lsof -i:4505

  COMMAND     PID USER   FD   TYPE DEVICE>  salt-mast 60444 root   12u  IPv4 145608      0t0  TCP *:4505 (LISTEN)
  [root@redis01-jp ~]# lsof -i:4506

  COMMAND     PID USER   FD   TYPE DEVICE>  salt-mast 60464 root   20u  IPv4 145637      0t0  TCP *:4506 (LISTEN)
  [root@redis01-jp ~]#
  [root@redis02-jp ~]# vim /etc/salt/minion
  [root@redis02-jp ~]# sed -n '17p;79p' /etc/salt/minion
  master: redis01-jp
  id: redis02-jp
  [root@redis02-jp ~]# service salt-minion start
  Starting salt-minion daemon:                               [  OK  ]
  [root@redis02-jp ~]#
  [root@redis01-jp ~]# salt-key -L
  Accepted Keys:
  Denied Keys:
  Unaccepted Keys:
  redis02-jp
  Rejected Keys:
  [root@redis01-jp ~]# salt-key -a redis02-jp      添加指定ID的key
  The following keys are going to be accepted:
  Unaccepted Keys:
  redis02-jp
  Proceed? [n/Y] y
  Key for minion redis02-jp accepted.
  [root@redis01-jp ~]# salt-key -L
  Accepted Keys:
  redis02-jp
  Denied Keys:
  Unaccepted Keys:
  Rejected Keys:
  [root@redis01-jp ~]#
  关于master的认证:
  salt-key  的基本命令:
  salt-key -L #检测当前server端所有minion端key的情况,三种:接收、等待接收和拒绝
  salt-key -a minion_id    #指定接收某台minion的key
  salt-key -A    #接收Unaccepted Keys下所有的minion
  salt-key -d  minion_id   #删除已经接收的机器中指定机器minion key (Accepted Keys:)
  salt-key -D   #删除已经接收的所有机器(Accepted Keys:)
  salt-key -y
  自动认证
  [root@redis01-jp ~]# sed -n '215p' /etc/salt/master
  auto_accept: True
  [root@redis01-jp ~]# service salt-master restart
  Stopping salt-master daemon:                               [  OK  ]
  Starting salt-master daemon:                               [  OK  ]
  [root@redis01-jp ~]#
  用法与帮助
  salt [options] '<target>' <function> [arguments]
  -E   可以用正则表达式来匹配对象
  -L   以列表的形式来指定对象
  -G  根据默认的grain的结果 执行模块
  -N  匹配指定的组
  salt '' sys.doc           #查看所有执行模块的doc
  salt  '' sys.doc test   #查看test模块的帮助
  salt '*' sys.doc test.ping   #查看test.ping函数的帮助
  salt '*' sys.list_functions grains  #列出模块的相关函数

运维网声明 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-544057-1-1.html 上篇帖子: Saltstack之系统初始化 下篇帖子: saltstack (2) 常用模块
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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