update @2019/03/19node
以前使用vmware vCenter管理虚拟机, 咱们在作模版时就将控制节点的公钥放入了虚拟机模版, 所以使用模版新建的虚拟机均可以直接从控制节点免密钥登陆的, 可以有效解决虚拟机密码被改了没法登陆的问题, 以及经过控制节点来作一些软件安装/配置修改和服务监控等。shell
最近在OpenStack
上新建了100多台机器, 这些机器一开始并无内置公钥, 机器开机后要对他们进行初始化, 如修改yum源和主机名, 经常使用工具安装, SELINUX/iptables禁用, vim设置优化等, 逐一手动修改工做量无疑会大到让人奔溃, 在不熟悉Ansible
的状况下, 咱们要作的第一步就是将控制节点的公钥拷贝到远程虚拟机上, 可是一个个的执行ssh-copy-id
还要输入不一样的随机密码,也会累死人的。有没有比较好的shell脚原本实现呢? 摸索了一下, 找到了对应的解决办法;vim
sshpass (添加epel源进行安装)
ssh-copy-id (centos已内置)
将须要添加公钥的主机名/IP地址/主机密码存入到文本文件hostsname.txt
中,格式以下:centos
node01 10.0.0.21 9nDvik7w node02 10.0.0.22 5fDviDEw node03 10.0.0.23 FiPp2UpR node04 10.0.0.24 KeMbe57z node05 10.0.0.25 FElJ3ArM
使用sshpass
将密码传递给ssh-copy-id
, 使得当须要输入密码时, 可以自动读取变量进行输入并完成验证.
本脚本在原来的基础上添加了一些附加功能, 包括:bash
脚本copy_ssh_id.sh
以下:session
vim copy_ssh_id.sh #!/bin/bash rm -f ./authorized_keys; touch ./authorized_keys sed -i '/StrictHostKeyChecking/s/^#//; /StrictHostKeyChecking/s/ask/no/' /etc/ssh/ssh_config sed -i "/#UseDNS/ s/^#//; /UseDNS/ s/yes/no/" /etc/ssh/sshd_config cat hostsname.txt | while read host ip pwd; do sshpass -p $pwd ssh-copy-id -f $ip 2>/dev/null ssh -nq $ip "hostnamectl set-hostname $host" ssh -nq $ip "echo -e 'y\n' | ssh-keygen -q -f ~/.ssh/id_rsa -t rsa -N ''" echo "===== Copy id_rsa.pub of $ip =====" scp $ip:/root/.ssh/id_rsa.pub ./$host-id_rsa.pub #cat ./$host-id_rsa.pub >> ./authorized_keys echo $ip $host >> /etc/hosts done cat ~/.ssh/id_rsa.pub >> ./authorized_keys cat hostsname.txt | while read host ip pwd; do rm -f ./$host-id_rsa.pub echo "===== Copy authorized_keys to $ip =====" scp ./authorized_keys $ip:/root/.ssh/ scp /etc/hosts $ip:/etc/ scp /etc/ssh/ssh_config $ip:/etc/ssh/ssh_config scp /etc/ssh/sshd_config $ip:/etc/ssh/sshd_config ssh -nq $ip "systemctl restart sshd" done
在CRT会话窗口中, 勾选使用Send command to all sessions
选项同时将命令cat .ssh/authorized_keys
发送到ssh主机:ssh
[root@gateway01 ~]# cat .ssh/authorized_keys ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEA7S0v0xsVaYB1B0NL/tzX0BkFttUWfBqYCL/LokSe3B6fgajY+b5FhxkCElGGvZKdGRQGqL07hcLcDHE3eWldOqv1jJ/rNO/omlogvs0dZwr9vI8QCmb/98ZHKTLrd3iDVMX4WiSTJ1mgxHIKFz6I1K0whcMObioyr8dFHWWTMSx2LDshGEsFQBcNLfAdjMaYE9OOpo05jOxiMaPq8M1oE4sdcJ3yKZHGO1ZzibapUuHiSma2pMbdR2OGC8SSIs5lRif1UUqg9rdsuztaikKpHSVYMrMZuIWW3jaAuJf8wZtnyaKU6y/GDm3H/SD0LWtRE7FUEBIT64aQjptcoOxoYw== root@deploy
[root@deploy ~]# ssh ngx-gw01 Warning: Permanently added 'ngx-gw01' (RSA) to the list of known hosts. Last login: Sun Mar 19 22:54:08 2017 from 172.20.224.202 [root@ngx-gw01 ~]#
第5步中没有提示要求输入yes
进行确认,是我以前就在ssh_config
文件中设置了不进行确认:工具
vim /etc/ssh/ssh_config #Add at the end of file StrictHostKeyChecking no
或者优化
sed -i '/StrictHostKeyChecking/s/^#//; /StrictHostKeyChecking/s/ask/no/' /etc/ssh/ssh_config