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

时间: 2025-01-31 02:01:21

linux如何配置双机SSH信任然后双向免密码登陆的相关文章

Linux中配置双机SSH信任 操作说明_Linux

一.实现原理 使用一种被称为"公私钥"认证的方式来进行ssh登录."公私钥"认证方式简单的解释是: 首先在客户端上创建一对公私钥(公钥文件:~/.ssh/id_rsa.pub:私钥文件:~/.ssh/id_rsa),然后把公钥放到服务器上(~/.ssh/authorized_keys),自己保留好私钥.当ssh登录时,ssh程序会发送私钥去和服务器上的公钥做匹配.如果匹配成功就可以登录了. 二.实验环境 A机:TS-DEV/10.0.0.163 B机:CS-DEV/

SSH免密码登陆

    SSH 的全称是Secure Shell,使用非对称加密方式,传输内容使用rsa 或者dsa 加密,可以有效避免网络窃听.有时候,需要能免密码登陆Linux系统,比如Hadoop操作,所以需要开启SSH免密码登陆.        注意,不用的用户生成的密钥是不同的,每个用户生成密钥都放在该用户主目录的".ssh"目录中:比如:root生成的密钥存放在"/root/.ssh",个人用户的存放在"/home/[username]/.ssh"目

使用key登陆管理linux服务器/免密码登陆linux服务器

ssh除了密码验证外,还有一种比较常用的验证方式:key:他的好处除了安全外,还可以实现linux之间的免密码登陆 ,方便管理或者批量维护. 本文介绍一下windows/linux下如何配置key免密码登陆linux服务器 01 [root@A ~]# ssh-keygen -t rsa 02   03 Generating public/private rsa key pair. 04   05 Enter file in which to save the key (/root/.ssh/i

ubuntu 12.04 ssh免密码登陆问题

问题描述 我用的是ubunun12.0.4系统,防火墙已全关闭,authoriezed_keys为644,用ssh免密码登陆,sshlocalhost,总在最后一步提示Hostkeyverificationfailed,请问这是什么原因呢?

Hadoop集群最迅速的配置免密码登陆方法

1:多台机器互相免密登陆的思路(默认你的linux操作系统已经安装好ssh): 第一步:在各自的机器上面生成密钥: 在第1台机器上生产一对钥匙: ssh-keygen -t rsa 在第2台机器上生产一对钥匙: ssh-keygen -t rsa 在第3台机器上生产一对钥匙: ssh-keygen -t rsa ............ 第二步:将其它机器的公钥拷贝到第一台机器: ssh-copy-id 第一台机器(分别在其他机器执行此命令,注意,也在第一台机器上面将公钥拷贝到自己的机器上面)

使用ssh-keygen,实现免密码登陆linux的方法_Linux

1  本机创建ssh密钥 ssh-keygen 2  拷贝公共密钥到"被登陆机"输入密码, scp  id_rsa.pub  root@10.35.0.35:~/.ssh/id_rsa.pub 3  ssh到"被登陆机"把公共密钥输入 "authorized_keys"(如果多个机器都需要使用rsa密钥认证登录此机器的话,将这些机器产生的公钥全部输入到)"authorized_keys" cat  id_rsa.pub >

SSH免密码登陆原理

Master作为客户端,要实现无密码公钥认证,连接到服务器Salve上时,需要在Master上生成一个密钥对,包括一个公钥和一个私钥,而后将公钥复制到所有的Salve上.当Master通过SSH链接到Salve上时,Salve会生成一个随机数并用Master的公钥对随机数进行加密,并发送给Master.Master收到加密数之后再用私钥解密,并将解密数回传给Salve,Salve确认解密数无误之后就允许Master进行连接了.这就是一个公钥认证过程,期间不需要手工输入密码,重要的过程是将Mast

linux远程登录ssh免密码配置方法_Linux

一.情景 公司刚上几台Linux,现在要把主机之间都能远程ssh免密码登陆. 二.原理很简单,使用ssh-keygen 在主机A上生成private和public密钥,将生成的public密钥拷贝到远程机器主机B上后,就可以使用ssh命令无需密码登录到另外一台机器主机B上. 三.步骤 主机A: 1. 生成公钥和私钥文件id_rsa和id_rsa.pub (敲3下回车即可) [root@bogon ~]# ssh-keygen -t rsa Generating public/private rs

Hadoop-2.8.0集群搭建、hadoop源码编译和安装、host配置、ssh免密登录、hadoop配置文件中的参数配置参数总结、hadoop集群测试,安装过程中的常见错误

25.集群搭建 25.1 HADOOP集群搭建 25.1.1集群简介 HADOOP集群具体来说包含两个集群:HDFS集群和YARN集群,两者逻辑上分离,但物理上常在一起 HDFS集群: 负责海量数据的存储,集群中的角色主要有NameNode / DataNode YARN集群: 负责海量数据运算时的资源调度,集群中的角色主要有 ResourceManager /NodeManager 25.1.2服务器准备 本案例使用虚拟机服务器来搭建HADOOP集群,所用软件及版本: ü Vmware 11.