
文章目录
git push origin master报错如下
Enumerating objects: 1706, done.
Counting objects: 100% (1706/1706), done.
Delta compression using up to 16 threads
Compressing objects: 100% (1563/1563), done.
error: unable to rewind rpc post data - try increasing http.postBuffer
error: RPC failed; curl 65 OpenSSL SSL_read: OpenSSL/3.1.2: error:0A0003FC:SSL routines::sslv3 alert bad record mac, errno 0
send-pack: unexpected disconnect while reading sideband packet
Writing objects: 100% (1660/1660), 172.18 MiB | 5.53 MiB/s, done.
Total 1660 (delta 1056), reused 0 (delta 0), pack-reused 0
fatal: the remote end hung up unexpectedly
Everything up-to-date
这个 git push 报错的主要原因有两个,都与推送的数据量较大(172.18 MiB)有关:
-
http.postBuffer配置不足Git 默认的 HTTP POST 缓冲区大小通常为 1 MiB 或几 MiB,而你要推送的包体积达到 172 MiB,远超默认值。错误信息
unable to rewind rpc post data - try increasing http.postBuffer明确提示需要增大该缓冲区。 -
SSL/TLS 连接异常
OpenSSL SSL_read: ... sslv3 alert bad record mac表示在 SSL 传输过程中数据完整性校验失败,可能是由于网络不稳定、代理/防火墙干扰,或者 MTU(最大传输单元)问题导致数据包被截断或损坏。当http.postBuffer过小时,Git 可能尝试分块发送,但某些块在 SSL 层出现错误,进而触发curl 65(CURLE_SEND_FAIL_REWIND,即无法回滚重发数据)。
最终服务器端断开连接(remote end hung up),推送失败。Everything up-to-date 是 Git 在失败后显示的错误状态,实际上并未成功推送。
解决方案
-
增大
http.postBuffer(最直接)执行以下命令将缓冲区调整为 500 MiB:
bashgit config http.postBuffer 524288000然后重新推送。
-
检查网络与 SSL 设置
-
如果使用代理,尝试关闭或正确配置代理:
bashgit config --global --unset http.proxy git config --global --unset https.proxy -
临时禁用 SSL 验证(仅测试,不安全):
bashgit config http.sslVerify false测试成功后应恢复为
true。
-
-
使用 SSH 替代 HTTP(S)
如果远程仓库支持 SSH,将远程地址改为 SSH 格式(如
git@github.com:user/repo.git),可避免 HTTP 缓冲区及 SSL 相关问题。 -
拆分提交
将大改动拆分为多个较小的提交,分别推送,减少单次传输的数据量。
优先尝试增大 http.postBuffer,这是最常见且有效的解决方法。