前提背景:项目很大,有3GB大小,并且使用的是http协议外加代理的方式拉取项目
git拉取代码出现问题,报错如下:
vbnet
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上面看到有位老哥给出了一个解决思路成功解决。
shell
经过多次尝试和失败,以及无数次"远程连接意外断开"之后,我终于找到了一种适合我的方法。
思路是先进行浅克隆,然后用克隆的历史记录更新仓库。
$ git clone http://github.com/large-repository --depth 1
$ cd large-repository
$ git fetch --unshallow
那么我也是根据这个思路先浅克隆最近一次的提交再更新仓库。
ini
git -c http.proxy=http:xxx:xxx clone https:xxx.git --depth 1
浅克隆成功,但是更新仓库失败,还是报error: RPC failed
那么我将这个次数拉高,直接拉到30000次,这里建议尽可能地拉高次数,这样能够避免再次报错的情况。
ini
git -c http.proxy=http:xxx:xxx clone https:xxx.git --depth 30000
然后再次更新仓库
sql
cd large-repository
git fetch --unshallow
最后成功克隆仓库到本地。