这篇文章给大家分享的是shell实现批量免密钥登录的方法,相信大部分人都还没学会这个技能,为了让大家学会,给大家总结了以下内容,话不多说,一起往下看吧。
注意: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\";}
}
"
看完这篇文章,你们学会shell实现批量免密钥登录的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。