我有一个脚本,它读取一个文本文件,其中列出了所有节点:
node1
node2
node3
.
.
.
这是我的脚本:
#!/bin/bash
while read f; do
ssh-copy-id myusername@"$f"
ssh username@master.icinga.test.com
icinga2 pki ticket --cn '$f'
done < linux-list.txt
while read f; do
ssh myusername@"$f" '
yum install -y epel-release
wget --no-check-certificate https://packages.icinga.org/epel/7/release/noarch/icinga-rpm-release-7-1.el7.centos.noarch.rpm
yum install icinga-rpm-release-7-1.el7.centos.noarch.rpm
yum install -y icinga2 nagios-plugins-all
chown -R icinga:icinga /etc/icinga2 /var/lib/icinga2 /var/log/icinga2' </dev/null
ssh myusername@master.icinga.test.com icinga2 pki ticket --cn "$f" |
ssh myusername@"$f" 'cat >/tmp/pkicode'
scp ./zones.conf myusername@"$f":/etc/icinga2/zones.conf
done < linux-list.txt
1) 脚本应该登录到 Icinga 主机并icinga2 pki ticket --cn '$f'
为在该文件上找到的每个节点运行一个命令,linux-list.txt
并为每个主机生成一个票证
2)然后将这个生成的代码发送到每个节点($f)
完成上述所有命令后,脚本需要运行命令 icinga2 节点向导,该向导将启动问题/答案提示,并需要有人键入答案,如下所示。
Icinga master 的 FQDN 是master.icinga.test.com
,它的 IP 是10.20.20.1
. PKI 票证是我们之前在 Icinga 主机上生成的,并且对于每个主机都不同。
有什么办法可以自动化吗?
Y
Enter
master.icinga.test.com
Y
10.20.20.1
N
Y
[PKI Ticket created earlier on the Icinga master]
Enter
Enter
Y
Y
Enter
Enter
N
N
谢谢