当您尝试通过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来测试连接。