如何高效清理Git仓库中误提交的历史大文件指南

如何高效清理Git仓库中误提交的历史大文件指南"/

清理误提交到Git的历史大文件是一个需要谨慎处理的问题,因为一旦删除了这些历史记录,它们就无法恢复了。以下是一些步骤和建议,以帮助您安全地清理这些大文件:
### 1. 确认误提交的文件
首先,您需要确认哪些提交包含了这些大文件。您可以使用以下命令:
```sh git log --oneline --all -- <文件路径> ```
### 2. 创建一个分支来隔离更改
在删除历史之前,创建一个新的分支来隔离更改:
```sh git checkout -b clean-history ```
### 3. 删除文件
在新的分支上,删除这些大文件:
```sh rm <文件路径> ```
### 4. 撤销提交
使用以下命令撤销包含大文件的提交:
```sh git reset --hard ```
替换 `` 为包含大文件的提交的哈希值。
### 5. 删除提交记录
现在,您可以使用 `git rebase` 来移除这些提交。这将创建一个新的提交序列,其中不包含您想要删除的提交:
```sh git rebase -i ```
在打开的交互式编辑器中,选择要删除的提交并输入 `delete` 或 `drop`。
### 6. 强制推送
最后,您需要将更改强制推送到远程仓库:
```sh git

相关内容:

前言

哈喽!好久不见~

最近在思考转型的事情,好久没有更新文章了

不过看到我之前开发的视频剪辑工具 Clipify 收获了不少 star ,让我想起之前画的饼似乎才实现了一点点,所以利用了周末的空闲时间给 Clipify 项目重构了一下界面以及开发一些新功能。

预告一下,这是重构之后的新界面,后面我会写一篇文章介绍一下。

中途意识到现在使用的 WinForms + Blazor 技术栈,就像马拉火车,有种蒸汽朋克的复古感,虽然使用前端技术开发的界面很好看,但 WinForms 不能跨平台终究不是长久之计。

于是我便着手尝试迁移到 MAUI,虽然还不能支持 Linux,至少 Mac 还是可以的,也算是跨平台了吧…

然而我还没把项目跑起来呢,一不小心把一堆静态资源给提交进去了

就是下面这些文件

Clipify.Maui/wwwroot/lib/
Clipify.Maui/wwwroot/css/*.min.css
Clipify.Maui/wwwroot/temp/

这下 git push 超级慢,而且会占用大量空间

还好最终在大模型爷爷的帮助下解决了这个问题

不过我想总不能老是去打扰大模型爷爷啊,问题解决了还是得记录一下,以后遇到类似的情况也好处理。

使用git原生命令

这个问题其实老生常谈了

网上能查到的很多文章都会告诉你可以用以下命令解决

git rm -r --cached Clipify.Maui/wwwroot/lib
git rm --cached Clipify.Maui/wwwroot/css/*.min.css
git rm -r --cached Clipify.Maui/wwwroot/temp

这些命令会移除已提交的文件,但不会删除本地文件

但我这样做了之后还是不行,git push 的时候还是很慢

分析原因

那么问题来了,为什么 git rm --cached 没用呢?

原因是 git rm --cached 只会从当前 commit(工作区)中移除指定文件的 Git 跟踪,它不会修改过去的提交记录

它解决的是「现在开始不要再跟踪」的问题, 但历史上它已经跟踪过的文件,Git 还会一直保留在对象数据库(.git/objects)里

我在前面几个 commit 已经把 Clipify.Maui/wwwroot/lib 这类文件夹提交进去了

所以这个命令对于这个场景来说是没用的

关于作者: 网站小编

码农网专注IT技术教程资源分享平台,学习资源下载网站,58码农网包含计算机技术、网站程序源码下载、编程技术论坛、互联网资源下载等产品服务,提供原创、优质、完整内容的专业码农交流分享平台。

热门文章