码迷,mamicode.com
首页 > 其他好文 > 详细

拷贝ssh公钥到多台服务器上

时间:2014-06-07 10:42:57      阅读:208      评论:0      收藏:0      [点我收藏+]

标签:c   a   http   tar   int   get   

这篇文章几乎是对Push SSH public keys to multiple host的翻译,谢谢该作者。

使用SSH登陆、执行命令到远程机器需要输入密码,很多系统需要免输密码访问远程机器,比如hadoop主节点访问子节点时,这时可以使用ssh-copy-id命令将公钥拷贝到远程机器上,
比如: ssh-copy-id -i hduser@192.168.7.70

但如过面临很多机器,比如5,6,7,8台以上,一般会想到写个脚本,批量执行,但ssh-copy-id命令执行过程中有两处需要人工参与,

一是当你看到如下提问时,必须对每台机器回答yes or no,

The authenticity of host ‘myfirsthost.work.cainmanor.com (10.256.33.106)‘ can‘t be established.
RSA key fingerprint is fc:40:7c:de:b8:ac:a2:f5:d4:11:d0:0e:b2:77:8a:63.
Are you sure you want to continue connecting (yes/no)? yes

二是每台机器的密码,当你ssh-copy-id到每台机器时,需要输入访问这台机器的密码,

为了解决第一个问题,可以修改~/.ssh/config文件(没有则创建),把下面两行增加到该文件中,

StrictHostKeyChecking no
UserKnownHostsFile=/dev/null

在完成所有SSH拷贝动作后,记得用#号键注释掉(不注释也没事。。。)。

为了解决第二个问题,可以使用sshpass工具,该工具可能需要下载,我在Centos上需要手动下载rpm包安装。sshpass为ssh提供所需的密码,可以执行如下命令,

sshpass -p ‘PASSWORD‘ ssh-copy-id hduser@host

实际操作时,会把上面这条命令放到像下面这样的脚本文件里,并提供hosts文件,hosts文件记录所有需要拷贝公钥的机器,

for X in `cat hosts`
do
sshpass -p ‘PASSWORD‘ ssh-copy-id hduser@${X}
done

hosts文件记录host信息这种模式在批量执行ssh命令很常见。

在完成SSH公钥拷贝后,可以选择pssh工具批量执行命令。

拷贝ssh公钥到多台服务器上,布布扣,bubuko.com

拷贝ssh公钥到多台服务器上

标签:c   a   http   tar   int   get   

原文地址:http://www.cnblogs.com/dioncnblogs/p/3770129.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!