当您尝试通过SSH测试连接GitHub且遭遇“connection closed by remote host”的错误时,通常表明建立安全连接时发生了问题。以下步骤可能帮助解决这一问题:

  1. 检查SSH配置:
    确保 ~/.ssh/config文件中的配置是正确的。对于GitHub,确保配置如下:

    Host github.com
      User git
      HostName github.com
      IdentityFile ~/.ssh/your_private_key
      TCPKeepAlive yes
      IdentitiesOnly yes

    其中 your_private_key是您的私钥文件名。

  2. 检查网络连接:
    SSH错误有时可能是由于网络连接问题引起。确保您的网络稳定,并允许SSH流量(通常是端口22)。
  3. 确认GitHub服务器状态:
    前往GitHub Status页面检查是否有任何关于服务中断或延迟的公告。
  4. 更新SSH客户端:
    如果使用的是老旧的SSH客户端,有可能不支持GitHub所需的加密标准。更新到最新版本的SSH客户端可能解决兼容性问题。
  5. 验证SSH密钥:
    确保您使用的是一个已添加到GitHub账户的SSH密钥。可以通过 ssh -T git@github.com来测试。如果密钥未被GitHub识别,将需要添加您的公钥到GitHub帐户。
  6. 检查SSH密钥权限:
    ~/.ssh/目录下,私钥文件应该有 600的文件权限(仅文件所有者有读写权限),而 .ssh目录应该有 700的权限(仅文件所有者有读写执行权限)。使用 chmod命令来调整权限。
  7. 查看SSH日志:
    尝试增加SSH命令的详细输出来获取更多错误信息。可以通过运行 ssh -vT git@github.com来执行。日志中可能会提供关于问题原因的线索。
  8. SSH密钥类型与支持:
    GitHub可能不支持非标准或弱加密的密钥类型。确认您的密钥类型是GitHub所支持的。目前支持的是 RSA(至少2048位),Ed25519等。
  9. 禁用SSH版本1协议:
    确保您的SSH客户端没有尝试使用SSH版本1协议连接,因为GitHub不支持这一旧协议。
  10. 复查时间同步:
    确保您的系统时间是准确的。时间偏差过大可能会破坏SSH协议的安全认证,导致连接失败。
  11. 排查企业防火墙或代理:
    如果您处在企业网络环境下,可能企业防火墙或代理设置阻碍了连接。与您的IT部门交流,确保所需端口和出站连接被允许。
  12. 使用替代端口:
    如果默认的SSH端口22被屏蔽,GitHub也在端口443上提供SSH访问。要启用此功能,将以下内容添加到您的 ~/.ssh/config文件中:
Host ssh.github.com
  HostName ssh.github.com
  User git
  Port 443
  IdentityFile ~/.ssh/your_private_key

然后使用 ssh -T git@ssh.github.com来测试连接。

按照上述步骤逐一排查,应能定位并解决连接GitHub时的SSH问题。记得,每次更改配置文件或更新设置后,测试您的SSH连接,直到问题得到解决。如仍无法解决问题,可考虑与GitHub的技术支持联系求助。请保留所有的出错信息和您已经尝试的解决步骤细节,以便于技术人员为您提供针对性的帮助。

云服务器/高防CDN推荐

蓝易云国内/海外高防云服务器推荐


海外免备案云服务器链接:www.tsyvps.com

蓝易云安全企业级高防CDN:www.tsycdn.com

持有增值电信营业许可证:B1-20222080【资质齐全】

蓝易云香港五网CN2 GIA/GT精品网络服务器。拒绝绕路,拒绝不稳定。


百度搜索:蓝易云

蓝易云是一家专注于香港及国内数据中心服务的提供商,提供高质量的服务器租用和云计算服务、包括免备案香港服务器、香港CN2、美国服务器、海外高防服务器、国内高防服务器、香港VPS等。致力于为用户提供稳定,快速的网络连接和优质的客户体验。
最后修改:2023 年 12 月 10 日
如果觉得我的文章对你有用,请随意赞赏