Linux集群设置免密登录双向,Linux配置SSH双向免密认证

一、实现原理

使用一种被称为"公私钥"认证的方式来进行ssh登录。"公私钥"认证方式简单的解释是:

首先在客户端上创建一对公私钥(公钥文件:~/.ssh/id_rsa.pub;私钥文件:~/.ssh/id_rsa),然后把公钥放到服务器上(~/.ssh/authorized_keys),自己保留好私钥。当ssh登录时,ssh程序会发送私钥去和服务器上的公钥做匹配。如果匹配成功就可以登录了。

二、实验环境

node1机:192.168.5.10

node2机:192.168.5.20

三、Linux/Unix双机建立信任

3.1 在node1机生成证书

在node1机root用户下执行ssh-keygen命令,在需要输入的地方,直接回车,生成建立安全信任关系的证书。

[[email protected] ~]# ssh-keygen -t rsa

180120140598091.png

注意:在程序提示输入passphrase时直接输入回车,表示无证书密码。

上述命令将生成私钥证书id_rsa和公钥证书id_rsa.pub,存放在用户家目录的.ssh子目录中。

3.2 查看生成密钥的文件

[[email protected] ~]# ll /root/.ssh/

180120140598092.png

3.3 node1对node2建立信任关系

将公钥证书id_rsa.pub复制到机器node2的root家目录的.ssh子目录中,同时将文件名更换为authorized_keys,此时需要输入node2机的root用户密码(还未建立信任关系)。建立了客户端到服务器端的信任关系后,客户端就可以不用再输入密码,就可以从服务器端拷贝数据了。

[[email protected] ~]# scp -r /root/.ssh/id_rsa.pub 192.168.5.20:/root/.ssh/authorized_keys

180120140598093.png

3.4 node2对node1建立信任关系

在node2机上执行同样的操作,建立node2对node1的信任关系。

[[email protected] ~]# ssh-keygen -t rsa

180120140598094.png

查看文件

[[email protected] ~]# ll /root/.ssh/

180120140598095.png

[[email protected] ~]# scp -r /root/.ssh/id_rsa.pub 192.168.5.10:/root/.ssh/authorized_keys

180120140598096.png

注意:记得修改authorized_keys权限

[[email protected] ~]# chmod 600 /root/.ssh/authorized_keys

四、测试

在node1机上:

[[email protected] ~]# scp /opt/test.txt 192.168.5.20:/opt/

180120140598099.png

在node2机上:

[[email protected] ~]# scp /opt/test22.txt 192.168.5.10:/opt/

180120140598097.png

五、远程执行命令

命令格式:ssh [email protected] '远程命令或者脚本'

ssh root@192.168.5.10 'hostname'

180120140598098.png

下面关于SSH相关的文章您也可能喜欢,不妨参考下:

集群环境SSH免密码登录设置  http://www.linuxidc.com/Linux/2017-03/141296.htm

Linux基础教程:配置SSH免密码登陆 http://www.linuxidc.com/Linux/2017-07/145847.htm

远程SSH连接服务与基本排错  http://www.linuxidc.com/Linux/2017-05/143738.htm

使用SSH公钥密钥自动登陆Linux服务器 http://www.linuxidc.com/Linux/2017-02/140642.htm

配置SSH免密码登录  http://www.linuxidc.com/Linux/2017-08/146213.htm

开启SSH服务让Android手机远程访问 Ubuntu 14.04  http://www.linuxidc.com/Linux/2014-09/106809.htm

SSH非交互式密码授权远程执行脚本  http://www.linuxidc.com/Linux/2017-04/143180.htm

SSH通过密钥登陆 http://www.linuxidc.com/Linux/2017-06/144997.htm

Ubuntu 安装配置SSH(ssh: connect to host localhost port 22: Connection refused问题的解决)  http://www.linuxidc.com/Linux/2015-01/112045.htm

CentOS SSH提示:connect to host centos-py port 22: Connection refused  http://www.linuxidc.com/Linux/2017-11/148586.htm

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值