linux如何配置双机SSH信任然后双向免密码登陆

一、实现原理

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

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

二、实验环境

A机:TS-DEV/10.0.0.163

B机:CS-DEV/10.0.0.188

三、Linux/Unix双机建立信任

3.1 在A机生成证书

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

# ssh-keygen -t rsa



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

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

3.2 查看~/.ssh生成密钥的文件

# cd ~/.ssh

# ll



3.3 A对B建立信任关系

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

# scp -r id_rsa.pub 10.0.0.188:/root/.ssh/authorized_keys



3.4 B对A建立信任关系

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

# ssh-keygen -t rsa



# cd ~/.ssh/

# ll



# scp -r id_rsa.pub 10.0.0.163:/root/.ssh/authorized_keys



如果想让B,C同时可以scp不输入密码,传输A中的数据;

则要把B、C的公钥都给 A;

操作步骤:把两机器的id_rsa.pub中的数据都拷贝到A的/root/.ssh/authorized_keys文件中,一行表示一条;

A: scp -r id_rsa.pub 10.0.0.163:/root/.ssh/authorized_keys

B: scp -r id_rsa.pub 10.0.0.188:/root/.ssh/authorized_keys

测试 ssh root@10.0.0.188 'hostname' /// ssh root@10.0.0.163 'hostname'

如果连接反应慢,请修改以下两参数

/etc/ssh/sshd_config

GSSAPIAuthentication no

UseDNS no

然后重启service sshd restart

(0)

相关推荐

  • SSH证书让Putty免密码登陆Linux的方法

    这里介绍的不是双Linux环境下的SSH证书登陆,而是Windows下用Putty证书登陆至你的Linux服务器/VPS. 目前我用的是Putty中文版,来自GoogleCode的项目:http:// ...

  • Linux怎么配置双机SSH互相信任实现免密码登录?

    各位好,本篇将通过两台机器的配置介绍如何实现双向互相登录无需密码认证.本篇使用一种方式被称为"公私钥"认证的方式来进行ssh登录."公私钥"认证方式简单的解释是 ...

  • linux下设置ssh免密码登陆的配置步骤分享

    我有两台笔记本电脑上分别装有两个centos的虚拟机,一个IP为172.16.1.10(slave),一个IP为172.16.1.9(master)。 在slave上用root用户 vi /etc/h ...

  • CentOS双向免密码登录教程

    本文介绍CentOS服务器双向免密码登录:有需要的朋友可以过来看看吧! 原理: (这里两台机器以主机1.主机2表示,这里两台机器是对等的) 若主机1想要免密码登录主机2,需要主机2能够识别自己,这里就 ...

  • Linux实现密钥登陆/如何实现Linux免密码登陆?

    在工作的时候一般都建议使用密钥远程登陆Linux,一方面是为了安全起见,另外一方面也是为了工作方便,下面小编与大家分享一下如何实现Linux免密码登陆. 在上一篇的时候与大家分享了使用puttgen创 ...

  • 两台Linux主机如何建立ssh信任关系?

    在管理的服务器列表里或许有很多台Linux主机,它们之后互相访问以及做很多的事情相互作用,如果它们之间都是使用密码来访问那真的是太麻烦了,下面小编与大家分享一下如何建立两台Linux主机ssh信任关系 ...

  • CentOS系统的服务器上设置SSH免密码登陆的教程

    为系统管理员,你计划在 Linux 上使用 OpenSSH,完成日常工作的自动化,比如文件传输.备份数据库转储文件到另一台服务器等.为实现该目标,你需要从主机 A 能自动登录到主机 B.自动登录也就是 ...

  • Linux系统SSH免密码登陆远程服务器的技巧

    搭建Hadoop环境需要设置无密码登陆,所谓无密码登陆其实是指通过证书认证的方式登陆,使用一种被称为"公私钥"认证的方式来进行ssh登录.在linux系统中,ssh是远程登录的默认 ...

  • 通过SSH证书实现Putty免密码登录CentOS的方法

    使用puttygen.exe生成SSH密钥 1、下载Puttygen.exe 下载地址:http://puttycn.googlecode.com/files/puttyfile_0.60cn2.zi ...