当前位置:首页 >> 操作系统

CentOS配置SSH单向无密码访问的方法

最近在研究一款文件系统,需要远程给客户机安装软件,且需要无SSH密码访问,另外需要远程给客户机传文件,每次输入root密码很不方便,就想到用ssh key生成公钥、私钥来验证,而避免每次就必须输入root密码。

服务器架构:

系统:CentOS 6.5 x64

主控端A:192.168.0.150

远端主机B:192.168.0.151

原理:

利用ssh key生成公钥、私钥,密钥相当于一把钥匙,而公钥就相当于一把门锁,我们当然是拿着钥匙去开锁,同样的道理,我们密钥放在本地服务器,也就是服务器A,把公钥放在远程服务器,也就是远端主机B,那么我们就可以从主控端A ssh免密码登陆到远端主机B了。

步骤:

1、在主控端A主机上生成无SSH密码访问的公钥和私钥文件

[root@localhost ~]# ssh-keygen -t rsa

CentOS配置SSH单向无密码访问的方法

注:执行命令中,连续按三次回车即可生成。

2、从主控端上传公钥到远端主机B上

[root@localhost ~]# ssh-copy-id -i /root/.ssh/id_rsa.pub root@192.168.0.151

CentOS配置SSH单向无密码访问的方法

中间需要输入一次远端主机B的root密码

3、在主控端测试无密码SSH远程远端主机B

[root@localhost ~]# ssh root@192.168.0.151

CentOS配置SSH单向无密码访问的方法

可以看到已经不输主机B的root密码,即可从A SSH远程到B了。