GIT - 清除历史 Commit 瘦身仓库

目录

一.引言

二.仓库清理

[◆ 创建一个船新分支](#◆ 创建一个船新分支)

[◆ 提交最新代码](#◆ 提交最新代码)

[◆ 双指针替换分支](#◆ 双指针替换分支)

三.总结


一.引言

由于项目运行时间较长,分支较多,且分支内包含很多不同的大文件,随着时间的推移,历史 Git 库的容量日渐增发,objects 里 pack 就高达 3G +,如果从头往下 pull 项目要花好久,下面开始项目瘦身。

Tips:

请确保待瘦身删除内容不涉及到 git reset 回退且不会再用到,否则删除了无法恢复

二.仓库清理

网上大佬们给了几种清理方法:

**filter-branch:**filter-branch 剔除指定的类型文件,并重写commitId。

BFG Repo-Cleaner: 仓库清理工具,筛选清理大文件对象。

这里博主直接偷懒了,由于之前很多提交已经无关紧要,所以我们直接将之前的提交抹去

◆ 创建一个船新分支

--orphan 会创建一个全新的分支,其与其他分支都没关系,也没有任何提交记录。可以理解为是一个纯净的空分支,我们后续只保留最新代码在该分支。

python 复制代码
git checkout --orphan <new-branch-name>

=> Switched to a new branch 'CleanGit'

◆ 提交最新代码

-A 会把本地的代码、文件全部推送到当前分支,在未 commit 之前,当前分支包含 0 个 commit,是全新的分支。

bash 复制代码
git add -A
git log

=> fatal: your current branch 'CleanGit' does not have any commits yet

git commit -am "Initial commit"

=> [CleanGit (root-commit) 96dc82a] Initial Commit
=> 137 files changed, 21462 insertions(+)

◆ 双指针替换分支

删除本地分支 -> 将当前分支重命名 -> 强制推送至远程分支,这个有点像 python 的双指针赋值 a, b = b, a,相当于做了一次轮转,把老的 commit 全部 -f 冲掉了。

python 复制代码
git branch -D <old-branch-name>
git branch -m <old-branch-name>
git push -f origin <old-branch-name>

三.总结

重复上述步骤,把 commit 多的分支清空或者删除,缩减 git 容量。不过最好还是在根源处避免在 git 中上传过大的文件。

相关推荐
sduwcgg2 小时前
git经验
git
麻雀无能为力3 小时前
git的使用
git
算法歌者5 小时前
Visual Studio 项目 .gitignore 文件指南
git·visual studio
江边垂钓者6 小时前
git cherry-pick和git stash命令详解
git
Lw老王要学习6 小时前
Linux架构篇、第五章git2.49.0部署与使用
linux·运维·git·云计算·it
爱学习的张哥6 小时前
专栏项目框架介绍
git·fpga开发·udp·ddr·gt收发器
Aric_Jones8 小时前
lua入门语法,包含安装,注释,变量,循环等
java·开发语言·git·elasticsearch·junit·lua
Sapphire~15 小时前
odoo-049 Pycharm 中 git stash 后有pyc 文件,如何删除pyc文件
ide·git·pycharm
Willis_m19 小时前
Linux 服务器用 SSH 拉取多个 Git 工程
linux·服务器·git·ssh
1candobetter19 小时前
git如何将本地 dev 分支与远程 dev 分支同步
git