Linux SSH 远程登录错误解决办法 WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!

      最近在登录一台机器的时候,发现无法等入了,出现以下错误:


于是就度娘(不得不说搜索引擎是个好东西),找了好久发现有篇文章里面提到.ssh/known_hosts文件,查看果然有这个文件:

就想这文件是个啥东东,待一查,才明白了,原来known_hosts是记录远程主机的公钥的文件,之前重装个系统,而保存的公钥还是未重装系统的系统公钥,在ssh链接的时候首先会验证公钥,如果公钥不对,那么就会报错,

解决办法:

1、将known_hosts文件中的与登录错误的IP的公钥删除即可,下图就是我的218机子的公钥(实则是之前系统的公钥),然后将其删除,再ssh 登录 great 登录成功了。

2、将known_hosts文件中的内容清空即可,但不建议使用此方法,里面还保存有其他机子的公钥。

3、使用shh-keygen 命令(强烈建议使用此方法

比如我们要将172.16.152.209的公钥信息清除,使用命令(请自己将172.16.152.209替换成自己的IP或域名):

ssh-keygen -R 172.16.152.209

如下图:


完毕之后就可以了,再次登陆就后要求确认是否公钥:



至此ssh链接错误成功解决,记录 在此以供查询。

### 解决方案 当遇到 `WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!` 警告时,表明本地保存的远程主机密钥与当前尝试连接的主机所提供的密钥不匹配[^1]。这可能是由于服务器更换了硬件、重装了操作系统或是SSH服务被重新配置等原因造成的。 为了消除这个警告并继续安全地建立SSH连接,可以采取如下措施: #### 方法一:删除旧有记录中的主机密钥 对于大多数Linux和macOS系统而言,在终端输入命令来移除特定主机的条目即可解决问题: ```bash ssh-keygen -R <hostname_or_IP> ``` 这条指令将会清除已知主机文件里对应于指定名称或IP地址的那一行数据,使得下次再访问同一台机器的时候能够接受新的公钥认证请求[^3]。 #### 方法二:手动编辑known_hosts 文件 另一种方法是直接打开用户的home目录下的`.ssh/known_hosts`文件,并找到包含目标主机信息的那一行将其删除。具体操作取决于所使用的操作系统以及个人偏好;不过一般推荐使用上述自动化的方式来进行处理以减少误操作的风险。 #### Windows 用户注意事项 针对Windows平台上的PowerShell环境,则应按照下面的形式调用相同功能的cmdlet : ```powershell ssh-keygen -R <hostname_or_IP> ``` 请注意替换 `<hostname_or_IP>` 为实际要连接的目标设备的名字或者网络位置表示法(IPv4/v6 地址)。 通过以上任一种手段都可以有效解决因为主机密钥变化而导致的身份验证失败问题,从而恢复正常的服务访问流程。
评论 24
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值