ssh-keygen的使用方法及配置authorized_keys两台linux机器相互认证

本文详细介绍如何通过生成RSA或DSA密钥实现两台Linux机器间的SSH免密登录,包括单向和双向登录的具体步骤及注意事项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文:http://blog.youkuaiyun.com/xiaoyida11/article/details/51557174


一、概述

1、就是为了让两个linux机器之间使用ssh不需要用户名和密码。采用了数字签名RSA或者DSA来完成这个操作

2、模型分析

假设 A (192.168.20.59)为客户机器,B(192.168.20.60)为目标机;

要达到的目的:
A机器ssh登录B机器无需输入密码;
加密方式选 rsa|dsa均可以,默认dsa

 

二、具体操作流程

 

单向登陆的操作过程(能满足上边的目的):
1、登录A机器 
2、ssh-keygen -t [rsa|dsa],将会生成密钥文件和私钥文件 id_rsa,id_rsa.pub或id_dsa,id_dsa.pub
3、将 .pub 文件复制到B机器的 .ssh 目录, 并 cat id_dsa.pub >> ~/.ssh/authorized_keys
4、大功告成,从A机器登录B机器的目标账户,不再需要密码了;(直接运行 #ssh 192.168.20.60 )

 

双向登陆的操作过程:

1、ssh-keygen做密码验证可以使在向对方机器上ssh ,scp不用使用密码.具体方法如下:
2、两个节点都执行操作:#ssh-keygen -t rsa
  然后全部回车,采用默认值.

3、这样生成了一对密钥,存放在用户目录的~/.ssh下。
将公钥考到对方机器的用户目录下,并将其复制到~/.ssh/authorized_keys中(操作命令:#cat id_dsa.pub >> ~/.ssh/authorized_keys)。



4、设置文件和目录权限:

设置authorized_keys权限
$ chmod 600 authorized_keys 
设置.ssh目录权限
$ chmod 700 -R .ssh

 

5、要保证.ssh和authorized_keys都只有用户自己有写权限。否则验证无效。(今天就是遇到这个问题,找了好久问题所在),其实仔细想想,这样做是为了不会出现系统漏洞。

我从20.60去访问20.59的时候会提示如下错误:

[java]  view plain copy
  1. The authenticity of host '192.168.20.59 (192.168.20.59)' can't be established.  
  2. RSA key fingerprint is 6a:37:c0:e1:09:a4:29:8d:68:d0:ca:21:20:94:be:18.  
  3. Are you sure you want to continue connecting (yes/no)? yes  
  4. Warning: Permanently added '192.168.20.59' (RSA) to the list of known hosts.  
  5. root@192.168.20.59's password:   
  6. Permission denied, please try again.  
  7. root@192.168.20.59's password:   
  8. Permission denied, please try again.  
  9. root@192.168.20.59's password:   
  10. Permission denied (publickey,gssapi-with-mic,password).  

 

三、总结注意事项

1、文件和目录的权限千万别设置成chmod 777.这个权限太大了,不安全,数字签名也不支持。我开始图省事就这么干了

2、生成的rsa/dsa签名的公钥是给对方机器使用的。这个公钥内容还要拷贝到authorized_keys

3、linux之间的访问直接 ssh 机器ip

4、某个机器生成自己的RSA或者DSA的数字签名,将公钥给目标机器,然后目标机器接收后设定相关权限(公钥和authorized_keys权限),这个目标机就能被生成数字签名的机器无密码访问了

补充:

jenkins master和slave通信的方式:

将master的public key拷贝到slave的~/.ssh/authorized_keys中,将slave 的 private key 保存到master上某ppk文件中。

jenkins将会自动地完成其他的配置工作,例如copy slave agent的binary,启动和停止slave。


<think>嗯,用户遇到了一个错误信息:“-bash: .ssh/authorized_keys: No such file or directory”。我需要先弄清楚这个错误通常是在什么情况下出现的。通常,当用户尝试操作一个不存在的文件或目录时,会出现这样的错误。具体来说,这里的路径是.ssh/authorized_keys,这可能涉及到SSH密钥配置。 首先,用户可能是在尝试将公钥添加到authorized_keys文件中,但该文件或者.ssh目录可能不存在。比如,他们可能使用了像cat id_rsa.pub >> ~/.ssh/authorized_keys这样的命令,而如果.ssh目录不存在,或者authorized_keys文件不存在,就会报这个错误。 接下来,我应该分步骤考虑解决方法。首先,检查.ssh目录是否存在。如果不存在,需要创建它,并设置正确的权限。因为SSH对目录和文件的权限要求比较严格,权限设置错误可能导致SSH无法正常工作。 然后,检查authorized_keys文件是否存在。如果不存在,同样需要创建,并且设置适当的权限。权限方面,.ssh目录通常应该是700(drwx------),而authorized_keys文件应该是600(-rw-------)。 此外,用户可能需要生成SSH密钥对,如果还没有的话。生成密钥对后,将公钥复制到authorized_keys文件中。这里需要注意的是,如果用户的主目录权限不正确,也可能导致问题,所以应该确认用户主目录的权限是否为755(drwxr-xr-x)。 还需要提醒用户使用正确的命令来复制公钥,比如使用ssh-copy-id命令,这会自动处理authorized_keys的创建和权限设置,可能更方便,避免手动操作出错的可能性。 可能用户是在手动操作时遇到了问题,所以分步骤的指导很重要。同时,需要强调权限的重要性,因为即使文件存在,权限错误也会导致SSH连接失败。需要检查每一步的权限是否正确。 总结一下,解决步骤应该是: 1. 检查并创建.ssh目录,设置权限。 2. 创建authorized_keys文件,设置权限。 3. 生成SSH密钥对(如果需要)。 4. 将公钥添加到authorized_keys。 5. 验证整个配置的权限是否正确。 另外,可能需要提醒用户如果使用的是非默认路径的SSH配置,或者有特殊的SSH服务器设置,可能需要检查sshd_config文件中的相关选项,比如AuthorizedKeysFile的路径是否正确,但这种情况可能较少见,尤其是默认配置下。 最后,确保用户理解每一步的目的,避免他们盲目执行命令,而是知道为什么要这样做。比如,解释权限设置的重要性,防止安全漏洞或者配置失败。</think>当你遇到 `-bash: .ssh/authorized_keys: No such file or directory` 错误时,通常是因为尝试操作不存在的 `.ssh/authorized_keys` 文件或 `.ssh` 目录。以下是逐步解决方案: --- ### **1. 确认 `.ssh` 目录是否存在** SSH 密钥相关文件默认存储在用户主目录的 `.ssh` 文件夹中。 **操作步骤:** ```bash # 检查目录是否存在 ls -al ~/.ssh ``` - **如果目录不存在**,手动创建并设置权限: ```bash mkdir -p ~/.ssh # 创建目录 chmod 700 ~/.ssh # 设置权限(仅用户可读写执行) ``` --- ### **2. 创建 `authorized_keys` 文件** 若文件不存在,需手动创建并设置权限。 **操作步骤:** ```bash touch ~/.ssh/authorized_keys # 创建空文件 chmod 600 ~/.ssh/authorized_keys # 设置权限(仅用户可读写) ``` --- ### **3. 生成 SSH 密钥对(可选)** 如果尚未生成密钥对,需先生成公钥/私钥。 **操作步骤:** ```bash ssh-keygen -t rsa -b 4096 # 生成 RSA 密钥对 ``` 生成的公钥默认保存在 `~/.ssh/id_rsa.pub`。 --- ### **4. 将公钥添加到 `authorized_keys`** 将公钥内容追加到 `authorized_keys` 文件中。 **操作步骤:** ```bash cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys ``` 或使用专用命令(自动处理权限): ```bash ssh-copy-id -i ~/.ssh/id_rsa.pub user@localhost ``` --- ### **5. 验证权限** SSH 对文件权限敏感,需确保以下权限正确: - 用户主目录权限:`755` (`drwxr-xr-x`) ```bash chmod 755 ~ ``` - `.ssh` 目录权限:`700` (`drwx------`) - `authorized_keys` 文件权限:`600` (`-rw-------`) --- ### **6. 测试 SSH 连接** 尝试通过密钥登录验证配置: ```bash ssh user@localhost ``` 若成功无密码登录,则配置正确。 --- ### **常见问题排查** - **路径错误**:确保操作路径是当前用户的 `~/.ssh/authorized_keys`。 - **权限问题**:使用 `ls -l ~/.ssh` 检查权限是否符合要求。 - **服务端配置**:检查 `/etc/ssh/sshd_config` 中 `AuthorizedKeysFile` 选项是否指向正确路径。 通过以上步骤,可解决文件或目录缺失问题并完成 SSH 密钥认证配置
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值