系统运维
注意:ip.txt和send_ssh_key.sh必须在同一根目录下
成都创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站建设、做网站、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的郾城网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!# 根据以下格式写入服务器信息ip.txt,用于免密钥登录
#-----------
# ip:password
#192.168.1.110:7758521
#192.168.1.111:7758521
#192.168.1.112:7758521
#-----------
#!/bin/bash
# 生成ssh key
if [[ ! -f /root/.ssh/id_rsa ]];then
echo gen ssh key
ssh-keygen -t rsa -b 2048 -N \'\' -f /root/.ssh/id_rsa
fi
# 检测是否安装了 expect
if ! expect -v &>/dev/null;then
echo install expect
yum install expect -y
fi
# 循环文件中的ip
for p in $(cat ip.txt|grep -v \'#\');do
ip=$(echo $p|cut -f1 -d:) # 取出当前IP
password=$(echo $p|cut -f2 -d:) # 取出当前密码
# expect 交互过程
expect -c
spawn ssh-copy-id -i /root/.ssh/id_rsa.pub root@$ip
expect {
\\*yes/no*\\ {send \\yes\\r\\; exp_continue}
\\*password*\\ {send \\$password\\r\\; exp_continue}
\\*Password*\\ {send \\$password\\r\\;}
}