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