解决ssh不能添加已访问的主机到信任列表的问题(Failed to add the host to the list of known hosts) .

解决ssh不能添加已访问的主机到信任列表的问题(Failed to add the host to the list of known hosts)

在ssh访问一个服务器的时候第一次会提示签名验证,只要同意之后就会将这个host添加到~/.ssh中的known_hosts中,以后再连接就不会再出现提示了。
   原来在ubuntu和freebsd下都没有这个问题。在Gentoo中就有点问题。今天解决了一下,在gentoo-user的mail list中找到了答案。
  正常的情况应该是这样的:
rory@gentoo ~ $ ssh xxx.xxx.com
The authenticity of host 'xxx.xxx.com (218.xxx.xxx.xxx)' can't be established.
RSA key fingerprint is 6e:6b:0f:2a:b8:91:3f:c8:f0:39:e4:df:b4:d8:16:6b.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added 'xxx.xxx.com,218.xxx.xxx.xxx' (RSA) to the list of known hosts.
rory@xxx.xxx.com's password: 

可是Gentoo中每次都出现:
rory@gentoo ~ $ ssh xxx.xxx.com
The authenticity of host 'xxx.xxx.com (218.xxx.xxx.xxx)' can't be established.
RSA key fingerprint is 6e:6b:0f:2a:b8:91:3f:c8:f0:39:e4:df:b4:d8:16:6b.
Are you sure you want to continue connecting (yes/no)? yes
Failed to add the host to the list of known hosts
rory@xxx.xxx.com's password: 

根据这位作者的回复:
http://www.mail-archive.com/gentoo-user@lists.gentoo.org/msg55719.html
可能是因为使用root用户来移动过home目录,应该修改一下.ssh的用户和权限
  1. chown username: /home/username/.ssh  
  2. chown username: /home/username/.ssh/*  
  3. chmod 700 /home/username/.ssh  
  4. chmod 600 /home/username.ssh/*  
chown username: /home/username/.ssh
chown username: /home/username/.ssh/*
chmod 700 /home/username/.ssh
chmod 600 /home/username.ssh/*

可是我看我的/home/rory/.ssh目录的用户和组都是正常的。所以就是因为目录的权限不对。对照作者说的我的.ssh没有x权限。所以我执行了 chmod 700 /home/rory/.ssh 。这样一切就正常了。
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
"Failed to add to the list of known hosts"是一种与SSH(Secure Shell)相关的错误消息。当您尝试通过SSH连接到远程主机时,SSH客户端会尝试将目标主机的指纹添加到已知主机列表中。然而,如果此操作失败,就会显示该错误消息。 通常,这个错误消息可能有以下几个原因: 1. 主机名或IP地址错误:请确认您输入的主机名或IP地址是否正确。如果主机名或IP地址无效,SSH客户端将无法将其添加到已知主机列表中。 2. SSH服务未启动:确认您尝试连接的目标主机上已经启动了SSH服务。如果SSH服务未运行,您将无法将其添加到已知主机列表中。 3. 已知主机列表文件权限问题SSH客户端尝试在已知主机列表文件(通常是known_hosts)中添加目标主机的指纹。然而,如果该文件的权限设置不正确,如只读或不可写,SSH客户端将无法进行添加操作。尝试更改该文件的权限为可写,并再次尝试连接。 4. 目标主机SSH密钥发生了变化:已知主机列表中存储了远程主机的公钥指纹,用于验证主机的身份。如果远程主机SSH密钥发生了变化,而您仍尝试将其添加到已知主机列表中,将会出现该错误消息。您可以手动编辑已知主机列表文件,将旧的指纹删除,并重新添加远程主机。 如果您遇到了"Failed to add to the list of known hosts"的错误消息,以上这些问题可能是导致问题的常见原因。通过仔细检查主机名、IP地址、SSH服务状态以及已知主机列表文件的权限,并确保目标主机SSH密钥没有发生变化,您通常可以解决这个问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值