网站首页 > 基础教程 正文
背景
最近我遇到了一个看似简单但暗藏玄机的需求——将一个Git仓库完整迁移到另一个远程仓库。理论上,这应该是再简单不过的任务:
Done!
但现实情况往往没那么顺利……
当我 push 到新仓库时,报错了。服务器拒绝了提交,原因是这个仓库存在大文件。
问题出在哪?
其实当我们手动删除大文件只是从最新代码里移除了它们,但实际上,它们仍然藏在 Git 的历史记录里。只要有人仔细翻看 commit 历史,还是能找到被删掉的大文件(甚至是敏感数据)。
这就像:
工作目录(最新代码)→ 干干净净
Git 历史(隐藏记录)→ 仍然藏着之前的文件
为了解决这个问题, 就需要彻底清理 Git 历史中的大文件,让仓库瘦身,成功 push 到新服务器!
准备示例
下面我们在Gitee上新建一个远程仓库来完整重现这个问题的场景。
首先在Gitee 删新建一个远程仓库:
拉取远程仓库
接下来我们在目录下添加一个大文件视频,并提交本地仓库, 然后删除大文件。
此时推送代码时, 推送失败。原因是当前文件为284.988MB超过最大100M。
BFG 删除历史文件
在操作之前, 使用--mirror对仓库进行备份,拷贝一份新仓库
目前我们代码还没有提交所以我们使用本地路径克隆本地仓库
下载BFG Repo-Cleaner,BFG是一个jar文件, 要求Java8 或更高版本的 Java 运行环境
https://repo1.maven.org/maven2/com/madgag/bfg/1.14.0/bfg-1.14.0.jar
将下载的jar 文件放在项目目录下, 使用--delete-filtes删除文件
删除大文件后即可提交成功
总结
本文介绍了如何彻底清理Git历史中的大文件,解决因超大文件导致推送失败的问题。通过BFG Repo-Cleaner高效移除隐藏的大文件,确保仓库瘦身、迁移顺利,并符合远程仓库的文件大小限制!
希望这篇文章能帮助你!如果你有任何问题或想法,欢迎在评论区分享!
猜你喜欢
- 2025-04-28 使用 Git 命令去管理项目的版本控制(二)
- 2025-04-28 腾讯云国际站代理商:如何搭建Git服务器?
- 2025-04-28 用git rebase命令合并开发阶段中多条commit提交记录
- 2025-04-28 git命令行打tag基础知识
- 2025-04-28 Git Rebase
- 2025-04-28 计算机知识 | Git版本控制流程
- 2025-04-28 计算机知识 | 在工作流中常用的Git命令
- 2025-04-28 如何完整迁移 Git 仓库 ?
- 2025-04-28 日常开发中常用的git操作命令和使用技巧
- 2025-04-28 Git下载安装以及必须知道的Git常用指令
- 04-28使用 Git 命令去管理项目的版本控制(二)
- 04-28腾讯云国际站代理商:如何搭建Git服务器?
- 04-28拯救你的 Git 仓库!用 BFG 秒删历史大文件,告别迁移失败
- 04-28用git rebase命令合并开发阶段中多条commit提交记录
- 04-28git命令行打tag基础知识
- 04-28Git Rebase
- 04-28计算机知识 | Git版本控制流程
- 04-28计算机知识 | 在工作流中常用的Git命令
- 最近发表
- 标签列表
-
- 菜鸟教程 (58)
- jsp (69)
- c++教程 (58)
- pythonlist (60)
- gitpush (78)
- pythonif (68)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- exec命令 (59)
- canvasfilltext (58)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- node教程 (59)
- console.table (62)
- c++time_t (58)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)