【🚀🚀】Github 仓库连接异常处理

背景

bash 复制代码
ssh: connect to host github.com port 22: Connection timed out
fatal: Could not read from remote repository.

Please make sure you have the correct access rights
and the repository exists.

众所周知 Github 的网页端访问极其不稳定, 用 http 协议 clone 仓库的时候非常难受, 但是用公钥走 ssh 协议进行连接体感稳定很多.

但是最近 ssh 也不行了, 稳定连接超时, 本地一堆仓库都没办法进行推送。

网上搜了一大圈, 发现都是加 ssh 配置, 增加下面的内容:

bash 复制代码
Host github.com
  Hostname ssh.github.com   Port 443 

意思是原先的 22 端口被关了, 换个 443 的端口就好了。

这么试了之后确实好了, 但是总感觉哪里不对劲, 因为我的印象里, 在指定 Hostname 的情况下, Host 的作用是别名。

也就是说这个配置项的作用其实是将所有连接到 github.com 的换到了 ssh.github.com

然后我把 Port 443 给注释了, 结果发现也能跑通, 这说明和端口压根没啥关系, 纯粹是域名的问题。

分别 ping 一下两个域名, 可以发现 github.com 完全不通, 但是 ssh.github.com 是通的。

bash 复制代码
ping github.com

正在 Ping github.com [20.205.243.166] 具有 32 字节的数据:
请求超时。
请求超时。
bash 复制代码
ping ssh.github.com

正在 Ping ssh.github.com [20.205.243.160] 具有 32 字节的数据:
来自 20.205.243.160 的回复: 字节=32 时间=87ms TTL=114
来自 20.205.243.160 的回复: 字节=32 时间=87ms TTL=114
来自 20.205.243.160 的回复: 字节=32 时间=86ms TTL=114

20.205.243.160 的 Ping 统计信息:
    数据包: 已发送 = 4,已接收 = 4,丢失 = 0 (0% 丢失),
往返行程的估计时间(以毫秒为单位):
    最短 = 86ms,最长 = 87ms,平均 = 86ms

至此, 可以确定就是最近解析的主域名 github.com 的 IP 被彻底被关了, 但是供 ssh 连接的子域名 ssh.github.com IP 还能用。

方案

因此, 解决方案就是添加下面的配置:

bash 复制代码
Host github.com  
  Hostname 20.205.243.160

将现有的 github.com 主机名换一个可以用的 IP。

另外, 找到了 Github 官方的文档 Using SSH over the HTTPS port.

这里面教你如何在 22 端口不可用时, 转用 443 端口, 但是 443 端口必须使用 ssh.github.com. 这也是网上大部分教程的出处. 但是由于这个问题不是端口导致的, 因此方法有效只是巧合罢了。

最后, Github 官方提供了它们的服务 IP 范围, About GitHub's IP addresses**, 从里面可以找一个 ssh 连接成功, 然后写到配置里。

相关推荐
ursazoo11 小时前
写了一份 7000字指南,让 AI 帮我消化每天的信息流
人工智能·开源·github
小兵张健15 小时前
Playwright MCP 截图标注方案调研(推荐方案1)
前端·javascript·github
哈基咪怎么可能是AI18 小时前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
九狼1 天前
Flutter URL Scheme 跨平台跳转
人工智能·flutter·github
逛逛GitHub2 天前
4 个热门的 GitHub 开源项目
github
程序员鱼皮2 天前
GitHub 关注突破 2w,我总结了 10 个涨星涨粉技巧!
前端·后端·github
HelloGitHub2 天前
《HelloGitHub》第 119 期
开源·github