踩坑日记:为什么Git 突然 Push 不上去了

今天在开发的时候遇到一个很离谱的问题,git push 明明昨天还好好的,结果今天突然完全推不上去。

报错信息如下:

vbnet 复制代码
ERROR: no healthy upstream
fatal: Could not read from remote repository.

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

或者是

vbnet 复制代码
ERROR: upstream connect error or disconnect/reset before headers.
remote connection failure, transport failure reason: delayed connect error: Connection refused
fatal: Could not read from remote repository.

一开始我以为是 GitHub 挂了,或者我 SSH key 失效了。结果一切正常:

vbnet 复制代码
ssh -T git@github.com

Hi shenlu89! You've successfully authenticated, but GitHub does not provide shell access.

我又查了一下远端Git仓库的URL是否正确:

scss 复制代码
git remote -v 
origin  git@github.com:shenlu89/docs.git (fetch)
origin  git@github.com:shenlu89/docs.git (push)

SSH 连接没有问题

  • 仓库地址没错
  • SSH 授权正常
  • git remote -v 正常

那问题从哪里来?

正常来说,使用 SSH 方式 push,那只要 ssh -T 可用,push 一定可用,但我这里:

java 复制代码
ssh -T git@github.com   // 正常
git push                // 失败

这说明 push 底层不是简单的 SSH 问题,而是 连接被代理或网络干扰了。

继续排查 macOS 系统代理:

arduino 复制代码
networksetup -getwebproxy "Wi-Fi"
networksetup -getsocksfirewallproxy "Wi-Fi"

结果是:

yaml 复制代码
Enabled: Yes
Server: 127.0.0.1
Port: 7890

也就是说,macOS 系统级 HTTP/HTTPS/SOCKS 都指向了 127.0.0.1:7890。

这就导致所有 Git 连接走系统代理,系统代理为空,请求被直接拒绝,Git push 报 connection refused

这就是为什么 SSH 测试能连,但 git push 反而失败。

因为 SSH 测试命令不走系统代理,而 Git push 走了。

直接关掉 macOS 的代理即可:

vbnet 复制代码
networksetup -setwebproxystate "Wi-Fi" off
networksetup -setsecurewebproxystate "Wi-Fi" off
networksetup -setsocksfirewallproxystate "Wi-Fi" off

然后:

perl 复制代码
git push

瞬间恢复正常。

还有一种方法,就是将 GitHub SSH 改用 443 端口,为了兼容各种奇怪网络环境(公司、学校、酒店 WiFi 等),我顺手也把 GitHub SSH 通道改到了 443 端口,编辑 ~/.ssh/config:

bash 复制代码
Host github.com
    HostName ssh.github.com
    Port 443
    User git
    IdentityFile ~/.ssh/id_ed25519
    IdentitiesOnly yes

443 端口一般不会被封,也不受代理影响,比 22 端口稳定太多。

这样问题就成功解决了。

相关推荐
solly79375567015 小时前
IDEA下载git项目和配置tomcat
git·tomcat·intellij-idea
拐爷15 小时前
Vibe‑coding九阳神功之夯:Git 基础操作,AI 时代的刹车系统(附速查表)
人工智能·git
i建模15 小时前
在Windows系统上通过SSH访问远程AWS主机
windows·ssh·aws
wypywyp16 小时前
6.linux环境优化——vscdoe ssh mobaxterm
linux·运维·ssh
gsgbgxp16 小时前
通过tailscale配置ssh远程实现wsl系统VSCode编程
vscode·深度学习·ubuntu·ssh
极智-99616 小时前
GitHub 热榜项目-日榜精选(2026-01-28)|实用资源与工具、开源LLM应用 | pi-mono、supermemory、mlx-audio等
开源·github·语音处理·密钥管理·llm应用·iptv资源
Lust Dusk16 小时前
如何通过GitHub找到一个人?
安全·网络安全·github
ONLYOFFICE16 小时前
ONLYOFFICE 桌面编辑器正式成为 ShaniOS 默认办公套件
linux·编辑器·github·onlyoffice
独自破碎E16 小时前
如何把本地文件夹和已存在的 GitHub 远程仓库同步
github
嘿吖嘿嘿~16 小时前
怎么解决git@github.com出现Permission denied (publickey)的问题
git·github