最近项目需要实现单边无密登录,去网上搜索了下相关文章,实践之后发现几乎都不能用。于是结合expect的使用方法自行写了一个,通过验证可用。现在总结在这供需要的朋友参考。
代码如下:
EXPECT=/usr/bin/expect
$EXPECT <<EOF
spawn ssh-keygen -t rsa
expect "*ssh/id_rsa*" {
send -- "\r"
expect "*for no passphrase*"
send -- "\r"
expect "*passphrase again*"
send -- "\r"
exp_continue
}
EOF
iplist=`cat /root/ip.list`
for ip in $iplist
do
$EXPECT <<EOF
spawn ssh-copy-id root@$ip
expect "*(yes/no)?*" {
send -- "yes\r"
expect "*?assword:*"
send -- "$PASSWD\r"
} "*?assword:*" {
send -- "$PASSWD\r"
exp_continue
}
EOF
done
更多精彩文章,请搜索微信公众号
“扶艾”
。我们定期分享
OpenStack
相关技术文章,在这里,只有
纯干货
。