清理误提交到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 这类文件夹提交进去了
所以这个命令对于这个场景来说是没用的
前言
哈喽!好久不见~
最近在思考转型的事情,好久没有更新文章了
不过看到我之前开发的视频剪辑工具 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 这类文件夹提交进去了
所以这个命令对于这个场景来说是没用的