RPC failed; curl 65 OpenSSL SSL_read: OpenSSL/3.1.2错误解决方法

文章目录

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)有关:

  1. http.postBuffer 配置不足

    Git 默认的 HTTP POST 缓冲区大小通常为 1 MiB 或几 MiB,而你要推送的包体积达到 172 MiB,远超默认值。错误信息 unable to rewind rpc post data - try increasing http.postBuffer 明确提示需要增大该缓冲区。

  2. SSL/TLS 连接异常
    OpenSSL SSL_read: ... sslv3 alert bad record mac 表示在 SSL 传输过程中数据完整性校验失败,可能是由于网络不稳定、代理/防火墙干扰,或者 MTU(最大传输单元)问题导致数据包被截断或损坏。当 http.postBuffer 过小时,Git 可能尝试分块发送,但某些块在 SSL 层出现错误,进而触发 curl 65CURLE_SEND_FAIL_REWIND,即无法回滚重发数据)。

最终服务器端断开连接(remote end hung up),推送失败。Everything up-to-date 是 Git 在失败后显示的错误状态,实际上并未成功推送。


解决方案

  1. 增大 http.postBuffer (最直接)

    执行以下命令将缓冲区调整为 500 MiB:

    bash 复制代码
    git config http.postBuffer 524288000

    然后重新推送。

  2. 检查网络与 SSL 设置

    • 如果使用代理,尝试关闭或正确配置代理:

      bash 复制代码
      git config --global --unset http.proxy
      git config --global --unset https.proxy
    • 临时禁用 SSL 验证(仅测试,不安全):

      bash 复制代码
      git config http.sslVerify false

      测试成功后应恢复为 true

  3. 使用 SSH 替代 HTTP(S)

    如果远程仓库支持 SSH,将远程地址改为 SSH 格式(如 git@github.com:user/repo.git),可避免 HTTP 缓冲区及 SSL 相关问题。

  4. 拆分提交

    将大改动拆分为多个较小的提交,分别推送,减少单次传输的数据量。

优先尝试增大 http.postBuffer,这是最常见且有效的解决方法。

相关推荐
明月_清风17 小时前
开发者网络概念全扫盲:一篇搞定
后端·网络协议
刘马想放假21 小时前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
王二端茶倒水2 天前
一套可落地的无线运营方案,不能只管 AP,还要管用户、计费和运维
网络协议
162723816082 天前
EtherCAT 分布式时钟(DC)原理与配置实战:把多轴真正"对齐到同一时刻"
网络协议
王二端茶倒水3 天前
宽带无线项目,怎么从一次性交付变成长期运营收入?
网络协议
用户2530171996274 天前
第6篇:从技术到产品 — Ghost Proxifier 的设计哲学
网络协议
用户2530171996274 天前
第3篇:注入的艺术 — Ghost Proxifier 核心架构拆解
网络协议
王二端茶倒水5 天前
商业 WiFi 不是免费上网,而是门店数字化的入口
网络协议
程序员mine10 天前
HTTPS-TLS加密与证书完全指南(中)
网络协议·https·ssl