解决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来测试连接。

posted @ 2025-09-07 11:50  csoe9999  阅读(42)  评论(0)    收藏  举报