git 大仓库拉取卡顿问题

在大仓库中执行 git fetchgit pull 迟迟没有反应,通常是由网络问题数据量过大导致内存/缓冲区溢出 、或认证卡死引起的。

(注:git pull 本质上是 git fetch + git merge,所以解决 fetch 的问题就能解决 pull 的问题。排查时建议先用 git fetch)。

你可以按照以下步骤逐步排查和解决:

第一步:开启调试模式(找出卡在哪)

不要干等,先让 Git 告诉你它在干什么。在命令前加上环境变量开启详细输出:

如果是 HTTPS 链接:

bash 复制代码
GIT_TRACE=1 GIT_CURL_VERBOSE=1 git fetch origin master -v

如果是 SSH 链接:

bash 复制代码
GIT_TRACE=1 GIT_SSH_COMMAND="ssh -v" git fetch origin master -v

根据输出的日志,你可以清楚地看到是卡在连接服务器(网络问题)、卡在鉴权(密码/密钥问题)、还是卡在下载对象(仓库太大)。


第二步:针对大仓库的专项优化

如果日志显示已经连上服务器,但卡在 Receiving objects 或长时间无响应,说明仓库太大,可以尝试以下方法:

1. 增大 Git 的通信缓冲区(最常见的解决方法) 大仓库拉取时很容易因为超出默认缓存大小而断开或假死。将缓冲区调大到 500MB 或 1GB:

bash 复制代码
git config --global http.postBuffer 524288000
# 如果还不行,可以尝试设为 1GB (1048576000)

2. 浅克隆/浅拉取(只拉取最新代码) 如果你不需要全部的历史记录,只想要最新的代码,可以限制深度:

bash 复制代码
git fetch origin master --depth 1

3. 无 Blob 拉取(Partial Clone) 这是 Git 较新的特性,特别适合大仓库。它会拉取所有的提交历史,但不下载具体的文件内容(Blob) ,只有在你 checkout 到具体文件时才按需下载:

bash 复制代码
git fetch origin master --filter=blob:none

4. 关闭/调整压缩(缓解 CPU 和内存压力) 如果你的电脑在处理巨型压缩包时卡死,可以尝试降低压缩率:

bash 复制代码
git config --global core.compression 0

第三步:排查网络与连接问题

如果日志显示卡在 Connecting to...,那就是网络问题。

1. 设置代理(如果访问的是 GitHub 等国外仓库) 如果你本地开启了科学上网工具,Git 默认是不会走代理的,需要手动设置(假设你的代理端口是 7890):

bash 复制代码
# HTTPS 协议设置代理
git config --global http.proxy http://127.0.0.1:7890
git config --global https.proxy http://127.0.0.1:7890

# 取消代理的命令(备用)
# git config --global --unset http.proxy
# git config --global --unset https.proxy

2. 切换传输协议(SSH vs HTTPS)

  • 如果你用的是 HTTPS (https://github.com/...) 卡住,尝试换成 SSH 协议 (git@github.com:...)。
  • 反之亦然。有时候公司网络或运营商会限制某一种协议。
  • 修改方法:git remote set-url origin <新的SSH或HTTPS地址>

第四步:排查认证卡死问题

有时候 Git 是在等待你输入密码或确认 SSH 密钥,但提示框没弹出来或者被隐藏了。

  • 测试 SSH 连接:如果你用的是 SSH,单独测一下能不能连通:

    bash 复制代码
    ssh -T git@github.com  # 如果是 GitLab 或 Gitee,替换为对应的域名

    如果这里卡住,说明是 SSH 密钥配置错误或端口被封。

  • 凭据管理器卡死 :如果你用的是 Windows,Windows Credential Manager 有时会弹窗失败导致后台挂起。尝试在任务管理器中强制结束 git-credential-manager.exessh-agent.exe,然后重试。

总结建议操作顺序:

  1. 先跑 GIT_TRACE=1 git fetch origin master -v 看日志。
  2. 如果是网络不通,配置代理切换 SSH/HTTPS
  3. 如果是仓库太大拉不动,依次执行:改大 Buffer -> 加入 --filter=blob:none 参数 -> 加入 --depth 1 参数
相关推荐
前端那点事1 小时前
告别低级冗余!10个前端原生高阶技巧,让代码更优雅、性能更出众
前端·vue.js
hexu_blog1 小时前
前端vue后端java如何实现证件照功能
前端·javascript·vue.js
豹哥学前端1 小时前
前端 LocalStorage 实战:从入门到熟练,一篇就够了
前端·javascript·面试
用户40189933422841 小时前
第 11 章 MCP 协议与集成
前端
Southern Wind1 小时前
谷记账——一个 Vue 3 批次记账 App
前端·javascript·vue.js
lzhdim2 小时前
SQL 入门 14:SQL 触发器与事件:自动化数据处理
linux·前端·数据库·sql·自动化
其实防守也摸鱼2 小时前
Sqlmap:选取sqli-labs中less-8进行sqlmap注入测试
前端·css·网络·安全·web安全·less·sqli-labs
伯远医学2 小时前
Nat. Methods | 邻近标记技术:活细胞中捕捉分子互作的新利器
java·开发语言·前端·javascript·人工智能·算法·eclipse
莪_幻尘2 小时前
一份 AGENTS.md,让 AI 代码规范率从 60% 飙升到 95%
前端·ai编程·cursor