当前位置:   article > 正文

vscode+remote突然无法连接服务器以及ssh连接出问题时的排错方法

vscode+remote突然无法连接服务器以及ssh连接出问题时的排错方法

设备描述

主机:win11,使用vscode的remote-ssh插件
服务器:阿里云的2C2GUbuntu 22.04 UFIE

状况描述

之前一直使用的是vscode的remote服务,都是能够正常连接服务器的,但是今天由于一些情况,我对服务器的系统进行了重装,然后我再想使用vscode连接服务器就连不上了,一直弹窗出错,重试了几次都没没什么效果。
我使用了阿里云自带的webbench,并使用ssh连接,发现没问题。于是我再次检查了服务器22端口的开启情况和防火墙的开启情况,发现也没有问题,于是怀疑是vscode出问题了。
再尝试卸载、重装remote_ssh插件后,情况依旧没有好转;于是又换用别的ssh连接工具(尝试了Tabby、XShell发现能正常连接),于是确定问题不在服务器

解决方法

经查,ssh协议在连接的时候会生成一个连接密钥,以标识该主机,该标识会被存储起来,方便下次访问的时候直接使用,而不用再次生成、接收
在ssh连接的报错信息中,出现了如下信息:
在这里插入图片描述

其中就已经明确指出:host key有问题,它在C:\users\Lenovo.ssh\known_hosts这个文件中,于是我顺着提示找到了这个文件,使用文本编辑器后打开,果然找到了相对的主机的Key。
在这里插入图片描述
在这里插入图片描述

这样一切都能说清楚了:

[!问题分析]
由于我重装了系统,ssh自然也重装了,服务器重新生成了密钥,但是我的vscode却不知道,还存储的是之前的密钥,因此在连接的时候,密钥对不上,就出现了连接失败的问题

因此,我们只需将相对应主机的相关Key全部删除就好了,再下次连接的时候重新获取服务器的ssh令牌(Key)。
再尝试连接服务器,重新获取Key,就发现能正常连接了。

当ssh连接出问题时的排错方法

那么当出现问题的时候我们应当如何排查呢?
以下是我的一些经验总结

  1. 首先查看服务器的ssh服务是否出问题了

    systemctl status sshd
    
    • 1

    如果看到的是类似如下的结果,百分之八十应该是没问题的:
    这说明ssh服务是正常开启的。

  2. 接下来就是检查防火墙是否关闭

    systemctl status firewalld
    
    • 1

    我的服务器不知道是为啥,似乎是装不了防火墙?反正没有,如果检查到防火墙处于running状态的要先将其暂停:

    systemctl stop firewalld
    
    • 1

    现在再试试能不能连上服务器了。
    如果还是不行,然后又不是我这种报错的,可以使用telnet命令,看看服务器的端口状态:

    telnet <IP> <PORT>
    
    • 1

    看看是否能够正常检测,检测成功会出现如下内容:在这里插入图片描述
    有极少数的情况就是22端口本身就被占用了,因此ssh服务可能使用其它端口用于监听连接,但是这种情况我不熟,也还没有碰到过,就暂时不说了吧。
    还有文章说,需要手动安装openssh:

    sudo apt install openssh
    
    • 1

    也可以试试吧,但我记得在安装ssh的时候默认就会有这个,似乎是不存在这个问题?

  3. 检查主机的ssh是否正常

  4. 若是上述方法试了还不行,就试着删除主机中所存储的Key吧,方法上面说了。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/195841
推荐阅读
相关标签
  

闽ICP备14008679号