Linux 下实现SSH互信

Linux 下实现SSH互信,第1张

一、准备两台服务器:

A机:192.168.1.1

B机:192.168.1.2

二、双机建立信任

1、在A机生成秘钥证书

在root下执行ssh-keygen命令,一路回车,生成秘钥证书

# ssh-keygen  -t  rsa  

2、查看生成秘钥文件

# cd ~/.ssh  

# ll

文件:私钥证书id_rsa、公钥证书id_rsa.pub

3、A对B建立信任关系

3.1 将公钥证书id_rsa.pub复制到机器B的root家目录的.ssh子目录中,同时将文件名更换为authorized_keys

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

3.2 若3.1报错:No such file or directory

使用:# ssh-copy-id -i id_rsa.pub root@192.168.1.2

ssh-copy-id命令会自动将id_rsa.pub文件的内容追加到远程主机root用户下.ssh/authorized_keys文件中

3.3 查看B机器是否接收

# ssh 192.168.1.2  

# cd .ssh/   

# ls   

# cat authorized_keys

# exit

3.4 B对A建立信任,同上3的 *** 作步骤

一、实现原理

使用一种被称为"公私钥"认证的方式来进行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

清除authorized_keys文件的内容(可以不用 *** 作)

将id_rsa.pub文件的内容复制到authorized_keys的末尾

windows重启ssh:net stop sshd,net start sshd

linux重启ssh:service sshd restart , systemctl restart sshd.service

windows本地的ssh地址

windows10 自带的有


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/bake/7933303.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-11
下一篇2023-04-11

发表评论

登录后才能评论

评论列表(0条)

    保存