Git 在传输数据时遇到的连接问题 error: RPC failed 导致代码拉不下来解决办法

22 阅读2分钟

前提背景:项目很大,有3GB大小,并且使用的是http协议外加代理的方式拉取项目

git拉取代码出现问题,报错如下:

remote: Enumerating objects: 50689, done. 
remote: Counting objects: 100% (50689/50689), done. 
remote: Compressing objects: 100% (16551/16551), done. 
error: RPC failed; 
curl 18 transfer closed with outstanding read data remaining 
error: 5800 bytes of body are still expected 
fetch-pack: unexpected disconnect while reading sideband packet 
fatal: early EOF 
fatal: fetch-pack: invalid index-pack output

交给AI分析得出是这些问题:

网络不稳定或中断,导致数据传输不完整。

Git 配置参数不适合,如传输缓冲区大小不足。

代理问题,可能会影响数据传输的稳定性,尤其是当代理不稳定时。

第二点可以排除,因为将缓冲区大小设置成了5GB大小都没用。同时因为环境问题,必须使用代理进行克隆,没法关闭代理。那么问题就出在网络问题身上了。

随后在stackoverflow上面看到有位老哥给出了一个解决思路成功解决。

经过多次尝试和失败,以及无数次“远程连接意外断开”之后,我终于找到了一种适合我的方法。
思路是先进行浅克隆,然后用克隆的历史记录更新仓库。  
$ git clone http://github.com/large-repository --depth 1 
$ cd large-repository 
$ git fetch --unshallow

那么我也是根据这个思路先浅克隆最近一次的提交再更新仓库。

git -c http.proxy=http:xxx:xxx clone https:xxx.git --depth 1 

浅克隆成功,但是更新仓库失败,还是报error: RPC failed

那么我将这个次数拉高,直接拉到30000次,这里建议尽可能地拉高次数,这样能够避免再次报错的情况。

git -c http.proxy=http:xxx:xxx clone https:xxx.git --depth 30000

然后再次更新仓库

cd large-repository 
git fetch --unshallow

最后成功克隆仓库到本地。