Salt Syndic是一个salt代理,当master需要管理大量的机器时,可以使用Syndic来帮助处理任务。
使用Salt Syndic需要满足以下要求:
1、Salt Syndic必须运行在一个master上,syndic的配置是在master上完成。2、Syndic要连到另一个master上,且比他等级更高。
环境部署
在两台master上(172.16.10.60和172.16.10.61)将60设置为master+syndic, 61为更高级的master
在60上安装salt-syndic:
# yum install salt-syndic -y
61上安装salt-master:
# yum install salt-master -y
修改60上syndic的配置:
# vim /etc/salt/mastersyndic_master: 172.16.10.61 #更高级的master
重启60上的salt服务:
# systemctl restart salt-master# systemctl restart salt-syndic
在61上配置其为更高级的master,修改maser配置文件在syndic区域中配置:
vim /etc/salt/masterorder_masters: True #开启高级master
重启master:
# systemctl restart salt-master
此时可以发现60上的master在61上被管理,同时,61也可以绕过60直接管理其它minion:
[root@node2 ~]# salt-keyAccepted Keys:Denied Keys:Unaccepted Keys: #收到syndic的keynode1Rejected Keys:[root@node2 ~]# salt-key -AThe following keys are going to be accepted:Unaccepted Keys:node1Proceed? [n/Y] YKey for minion node1 accepted.[root@node2 ~]# salt-key Accepted Keys:node1Denied Keys:Unaccepted Keys:Rejected Keys:[root@node2 ~]# salt '*' test.ping #直接管理minionnode1: Truenode2: True
sydic本质上是一个minion,接受更高级的master指令,收到指令后将信息给本地master,然后master对minion进行管理。 当执行完后,返会的信息会直接被syndic接收,syndic会将信息直接返回给上一级的master。这就是一个多级的层次关系,可以通过层级来管理更多的服务器。
注意: Syndic的file_roots 和pillar_roots必须与上一级的master保持一致。
上一级的master不知道自己到底有多少minion.