1.首先,需要检查expect是否安装:rpm -qa|grep expect
2.然后,在操作机上创建公钥:ssh-keygen 一路回车即可
3.创建好之后到/home/barfoo/.ssh/下就可以看到id开头的2个文件,其中id_rsa.pub就是公钥文件,
4.需要做的就是将这个文件传送给其他机器:ssh-copy-id -i /home/barfoo/.ssh/id_rsa.pub barfoo@ip
5.最后ssh root@ip就实现无密码登录了
6.以下是脚本,根据自己实际情况做修
#2017-05-18 #批量ssh认证建立 for p in $(cat /home/barfoo/ip.txt) #注意ip.txt文件的绝对路径 do ip=$(echo "$p"|cut -f1 -d":") #取ip.txt文件中的ip地址 password=$(echo "$p"|cut -f2 -d":") #取ip.txt文件中的密码 #expect自动交互开始 expect -c " spawn ssh-copy-id -i /home/barfoo/.ssh/id_rsa.pub barfoo@$ip expect { \"*yes/no*\" {send \"yes\r\"; exp_continue} \"*password*\" {send \"$password\r\"; exp_continue} \"*Password*\" {send \"$password\r\";} } " done安装好后执行
pssh -P -h ip.txt 'uptime 相关资源:七夕情人节表白HTML源码(两款)