git clone 失败的解决方法

       本人在使用 git clone 命令时,经常失败。看了许多网上已有的帖子,其方法并非十分有效。因此,我结合个人经验,总结出这篇文章。以方便大家解决git clone失败的问题。

目录

错误信息描述

解决方法

Step1.改变配置

1.1.增大缓冲区大小

1.2.调整最低网速和时间

1.3.更改通信协议

1.4.查看更改后的结果

Step2.改变克隆方式

最后:

递归克隆

Why?递归克隆能成功?递归克隆的原理是什么?


错误信息描述

error: RPC failed; curl 18 transfer closed with outstanding read data remaining
error: 6801 bytes of body are still expected
fetch-pack: unexpected disconnect while reading sideband packet
fatal: early EOF
fatal: fetch-pack: invalid index-pack output

Why?为什么会出现这个问题呢?

这是因为网速较慢,或者所需要git clone 的目标项目太大

解决方法

Step1.改变配置

注意:在其他帖子中,一般把以下3条分别作为3种不同方法描述。

而经本人实践发现,把下面3条一起用更加有效!!!

1.1.增大缓冲区大小

在终端输入以下命令即可设置:

git config --global http.postBuffer 524288000

这里表示把git clone的缓冲区设置为524288000B=500MB

1.2.调整最低网速和时间

在终端输入以下命令即可设置:

git config --global http.lowSpeedLimit 0
git config --global http.lowSpeedTime 999999

1.3.更改通信协议

因为git默认使用http/2.0协议,而github还是http/1.1 。 git 默认使用的通信协议是http/1.0,可以通过将默认通信协议修改为 http/1.1 来解决该问题

在终端输入以下命令即可设置:

git config --global http.version HTTP/1.1

建议:把上面的1.1、1.2、1.3一起使用

然后再进行Step2

1.4.查看更改后的结果

git config --global --list

Step2.改变克隆方式

  • 一般的克隆方式:
    git clone http://github.com/<file name>
    

    当出现以上报错信息时,建议把克隆方式改为下面这种:

  • 先浅克隆,再获取完整内容:(<--建议使用)
    git clone http://github.com/<file name> --depth 1
    cd <file name>
    git fetch --unshallow
    

       实践发现:一般git clone命令,在白天的成功率>晚上的成功率

       假如你已经按照Step1配置好,但是采用“先浅克隆,再获取完整内容”的方式仍然失败,可以再尝试多几次。因为可能不是你这边的网速不好,而是别人的服务器那边太繁忙。

       这个东西需要一点运气

最后:

奉上一个血与泪的教训:

假如克隆成功后,发现代码编译会报错,报错信息显示缺乏某些头文件

这时,请首先尝试采用以下的克隆方法:

递归克隆

$ git clone --recursive http://github.com/<file name>

 使用这句命令克隆后,再编译,一般就能成功了

Why?递归克隆能成功?递归克隆的原理是什么?

不难发现,递归克隆法相比于一般的克隆方法多了1个“recursive”(表示“递归”)

实际上,你所要克隆的目标项目project1可能调用了A人的项目projectA,而A人的项目可能调用了B人的项目projectB,………

如果使用一般的克隆方法,则只会克隆目标项目project1,这会导致在编译时缺乏某些头文件而报错。

如果使用递归克隆法,则不仅会克隆目标项目project1,还会克隆projectA,projectB…………从而不会报错

### Git Clone 失败的原因及解决方案 #### 可能原因分析 Git clone 操作失败可能由多种因素引起,常见的原因包括网络配置错误、代理设置不当以及证书验证问题。 1. **代理设置冲突** 如果用户的系统中设置了全局 HTTP 或 HTTPS 代理,而这些代理无法正常工作或者未被正确配置,则可能导致 `git clone` 请求被阻塞或超时[^2]。 2. **SSL 验证失败** 当目标仓库通过 HTTPS 访问时,可能会因为本地缺少有效的 SSL 证书而导致连接中断。这种情况下通常会收到类似于 “SSL certificate problem: unable to get local issuer certificate” 的错误提示[^3]。 3. **权限不足或其他网络限制** 用户账户缺乏访问远程存储库所需的适当权限也可能引发此问题;另外,在某些企业环境中由于防火墙策略等原因也会影响正常的克隆操作。 --- #### 解决方案详解 针对上述提到的各种潜在问题, 下面提供了一些具体的解决办法: ##### 方法一:清除不必要的代理设置 对于那些不需要使用任何特定类型的互联网网关来获取资源的情况来说,可以尝试移除现有的HTTP/HTTPS代理设定以排除干扰: ```bash git config --global --unset http.proxy git config --global --unset https.proxy ``` 该方法适用于无论是Windows还是Linux操作系统下的开发环境当中遇到的相关麻烦事例][^[^23]。 ##### 方法二:禁用SSL验证 (仅限临时措施) 如果是因为SSL认证方面存在问题的话,那么可以通过下面这条指令暂时关闭安全性检查从而绕过障碍继续完成任务(注意这并不是长久之计): ```bash git config --global http.sslVerify false git config --global https.sslVerify false ``` 这样做的后果就是使得客户端不再对服务器端传来的数据包进行身份确认过程,因此存在一定的安全隐患,请谨慎采用这种方式作为最终修复手段[^1]. > 注明:以上两个选项均需根据实际情况灵活运用,并且建议在成功解决问题之后重新开启sslverify功能以便保障通信安全。 ##### 方法三:更新CA根证书 有时可能是由于系统的 CA 根证书已经过期或者是不完整的缘故才造成了这样的状况发生。此时应该考虑升级openssl版本或是手动导入最新的cacert.pem文件到相应目录下供程序调用即可恢复正常运作状态. --- ### 总结 综上所述,Git Clone 出现异常多半是由外部条件所引起的而非软件本身缺陷所致。通过对症采取相应的调整动作基本上都能顺利化解困境回到正轨上来。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值