首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

从 git 的历史记录中彻底删除文件或文件夹

如果你对外开源的代码中出现了敏感信息(例如你将私钥上传到了仓库中),你可能需要考虑将这个文件从 git 的历史记录中完全删除掉。 本文介绍如何从 git 的历史记录中彻底删除文件或文件夹。...---- 第一步:修改本地历史记录 彻底删除文件: 1 git filter-branch --force --index-filter 'git rm --cached --ignore-unmatch...walterlv.xml' --prune-empty --tag-name-filter cat -- --all 其中 walterlv.xml 是本来不应该上传的私钥文件,于是使用此命令彻底删除...彻底删除文件夹: 1 git filter-branch --force --index-filter 'git rm --cached -r --ignore-unmatch WalterlvDemoFolder...第二步:强制推送到远端仓库 刚刚我们的操作仅仅发生在本地仓库,敏感信息需要删除的仓库通常都在远端,于是我们一定要将修改推送到远端仓库。

86320

被吐槽 GitHub仓 库太大,直接 600M 瘦身到 6M,这下舒服了

图片这目录好大那么.git目录是存放什么的?为什么会这么大呢?在Git系统中,.git目录中存储了整个代码仓库的元数据信息(包括提交历史记录、分支、标签等)和文件对象。...上边三种类型的对象组成了Git中的基本数据单元,通过这些对象的组合和链接,才构建出完整的提交历史,并跟踪代码库中每个文件的变化历史。...Git 库中的历史版本、清除废弃的、过期的对象,这个过程会耗费较长的时间。...图片每次提交都会生成一次快照,这些快照可能包含大量的文件和代码,频繁提交会导致版本库中快照的数量增加。Git使用的是一种增量存储方式,每次提交只存储发生了变化的文件和代码。...但是,如果频繁提交的变化较小,比如只是修改了几个字符或者行末空格,Git可能无法正确地检测出这些变化,而将整个文件都存储起来,也会增加了.git文件的大小。

1.1K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Git 仓库体积过大,缩减记录

    二、具体操作 首先,git仓库中删除历史大文件分为以下步骤: 查找大文件id→根据id查找大文件所在的路径→删除文件→删除文件的历史记录→提交→清除本地缓存 (我按照我的理解总结的,不知道是不是对的,如果有错误的话...删除文件的历史记录 $ git filter-branch --force --index-filter 'git rm --cached --ignore-unmatch --ignore-unmatch...首先,查看存储库中的大文件: 1....查看存储库中的大文件 $ git rev-list --objects --all | grep -E `git verify-pack -v .git/objects/pack/*.idx | sort...in refs/original/ Force overwriting the backup with -f 并告知所有组员,push 代码前需要 pull rebase,而不是 merge,否则会从该组员的本地仓库再次引入到远程库中

    6.3K10

    如何删除错误提交的 git 大文件

    早上小伙伴告诉我,他无法拉下代码,我没有在意。在我开始写代码的时候,发现我的 C 盘炸了。...那么如何把这个压缩包彻底从 git 删除? 如果需要删除 git 的历史记录,使用方法很简单,请看 Git如何永久删除文件(包括历史记录) - shines77 - 博客园 。...当然这个方法需要很长时间,因为提交大文件的时间不长,所以可以使用walterlv的方法 彻底删除 Git 仓库中的文件避免占用大量磁盘空间 - walterlv 于是远程仓库删好了,但是本地仓库还是有小伙伴拉下来...git gc --prune=now 第一句代码git fetch -f -p的作用就是从本地拿到远程最新分支,覆盖本地存放的远程分支 第二句实际上因为主要开发分支就是 dev 分支,小伙伴就是把大文件合并到这个分支...需要说明,git 如果提交一个文件,然后删除他,继续提交,那么这个文件是存在 git 中,需要使用特殊的命令才可以删除。

    3.1K10

    BFG Repo-Cleaner - 快速清除Git提交历史中的特定文件

    的另一种选择 BFG是git-filter-branch之外的一种更简单、更快的方法,可以清除Git存储库历史中的不良数据: 删除 大文件 删除 密码、凭证 和其他 私人数据 git-filter-branch...检查存储库以确保您的历史记录已更新,然后使用标准的git gc命令去除不需要的脏数据, git现在将这些脏数据视为多余的需求: $ cd some-big-repo.git $ git reflog expire...无论它们在您的存储库中的任何地方: $ bfg --replace-text passwords.txt my-repo.git 删除Git中所有名为'.git'的文件夹或文件—保留的文件名。...因此,BFG假定您的最新提交是一个好的提交,其中没有您希望从历史记录中删除的脏文件。BFG的这一假设保护了您的工作,并让您安心地知道BFG只是仅仅更改您的仓库历史记录,而不是干预项目的当前文件。...如果某个坏的文件(比如10MB的文件,当您指定--strip-blobs-bigger-than 5M)在受保护的提交中,那么它不会被删除—它将保存在您的存储库中,即使BFG从以前的提交中删除了它。

    3K40

    git 使用之remote: File size 104.090MB, e

    ,任何git项目遇到这个问题报错均可通用解决方案要解决这个问题,你需要从 Git 历史记录中删除这个大文件,然后再次推送你的更改。...从历史记录中删除大文件: 你可以使用 git filter-repo 来从历史记录中删除这个文件。...如果你还没有安装 git filter-repo,可以通过以下命令安装:pip install git-filter-repo然后,使用以下命令从历史记录中删除这个文件: git filter-repo...m "删除了大文件"强制推送更改: 最后,强制推送更改到远程仓库:git push origin master --force如果在第二步 遇到Aborting: Refusing to destructively...git clone https://gitee.com/youyacao/www.youyacao.com.git cd www.youyacao.com移除大文件: 在新的克隆仓库中移除大文件。

    17710

    Git+Gerrit如何永久删除历史文件(大文件私密文件)

    一、前言 前几天同事在拉取一个项目的Git仓库时,发现项目拉取速度非常慢,半个钟都无法拉取下来,并且发现一直卡在了99%的进度上。 ?...因为远程仓库中,大文件的提交记录依然存在,这样删除只是将产生了一个新的提交记录,将当前commit中大文件去掉而已,随时可以回滚回来,pull的时候依然会将大文件的历史记录拉取下来。...git reset --soft命令一样是无法将提交记录从仓库中抹掉的,虽然通过reset之后,大文件的提交记录在git log中已经查找不到,但实际上,这个记录并不会真正的从仓库中删除,只要能找到commit...id,依然可以从仓库中恢复该提交历史。...Git这么强大,肯定是存在可以永久删除历史记录的命令,找了一圈,发现确实有“后悔药”命令,那就是git filter-branch,通过以下命令,就可以永久删除你想要删除的任何文件: git filter-branch

    2.6K20

    从9G到0.3G,腾讯会议对他们的git库做了什么?

    注意事项:(开发重点关注) 瘦身期间会锁库,必须提前推送代码到远端,否则需要手动同步;锁库期间无法进行 MR,且已创建 MR 会失效;因删除历史记录,会导致本地仓库与远端冲突,请恢复后重新 clone...瘦身期间会锁库,必须提前推送代码到远端,否则需要手动同步; 锁库期间无法进行 MR,且已创建 MR 会失效; 因删除历史记录,会导致本地仓库与远端冲突,请恢复后重新 clone 代码; 需要查询或处理更老的代码...之所以这么做,是为了保证其他平台无缝对接新的 Git 仓库,不用再更换 Git 地址,另外有些通过 api 调用的系统和工具也不受到影响。 瘦身内容: 历史记录删除,只保留最近半年的历史记录。...特殊分支处理 说明:以上历史记录裁剪并删除历史提交记录执行完后,对于基于截断提交节点前的提交节点创建出来的分支或者其子分支会出现文件被删除或者整个分支被删除的情况。...包,然后就可以在 python 代码中作为库使用:import git_filter_repo as fr。

    98951

    【GIT版本控制】--常见问题与解决方案

    ,可以尝试从备份中恢复损坏的仓库。...在修复损坏的Git仓库时,请确保备份重要的数据。如果问题无法解决,最好从备份或远程仓库中重新克隆仓库,以避免数据丢失。此外,定期备份Git仓库是一种良好的实践,可以帮助你在出现问题时快速恢复数据。...二、恢复丢失的提交 恢复丢失的Git提交可能会发生在不小心删除提交或分支、强制推送(force push)后丢失历史记录等情况下。...备份或克隆: 如果以上方法都无法找回丢失的提交,如果你有一个备份或克隆了丢失提交之前的仓库,可以从备份或克隆中复制丢失的提交并重新应用到当前仓库中。...解决方法包括检查仓库完整性、删除损坏的对象、重新克隆仓库或使用备份。恢复丢失的Git提交可能由于提交被删除、分支覆盖或历史记录重写而发生。

    37730

    Git LFS 好用的大文件储存工具?

    提交代码 当您添加、修改或删除大文件时,Git LFS 将监视这些文件,并自动替换为Git LFS 指示文件。在执行添加、提交和推送操作之前,使用以下命令审核将要提交的大文件清单。...Git大文件存储使用指针来引用文件,而不是将实际文件或二进制大对象(blobs,一种将二进制文件存储为一个实体的数据类型) 存储在Git存储库本身中。...因此,大文件/二进制大对象不会被直接写入Git存储库,而是被写入一个指针文件。文件/二进制大对象本身会被写入一个单独的服务器,称为LFS存储库。...通过这种方式,可以对大文件进行版本控制,以及管理二进制大对象,同时释放Git存储库的空间。 应该使用Git LFS吗? 如果您需要在Git中管理大文件或二进制文件,那么可以考虑使用Git LFS。...这意味着每个存储库都需要安装Git LFS,您还需要告诉LFS要跟踪的文件类型,然后将跟踪信息添加到存储库中,以便在提交该类型的文件时,它将被放置在LFS存储库中。

    55220

    如何删除GIT仓库中的敏感信息

    前言 正常Git仓库中应该尽量不包含数据库连接/AWS帐号/巨大二进制文件,否则一旦泄漏到Github,这些非常敏感信息会影响客户的信息安全已经公司的信誉。...由于Git的正常操作流程,导致敏感信息一旦进入主分支,再怎么在新的Pull Request中删除,也无能为力了。其它人都能在历史记录中查询到历史记录中的配置。...这里我将演示一个故意写满“敏感信息”的Github仓库,然后一步一步演示怎么在历史记录中,删除“敏感信息”,以完成“脱敏”。...命令执行后,可以运行gitk,可以看到历史记录中,东西真的被替换了: ?...注意,简单地执行git push(不带--force)是无法推送的,此时会报如下错误: ?

    3K61

    Git GC命令清理Git暂存区

    最近发现本地仓库暂存区存储空间飙升了好几个G,然后发现我又不知道该怎么解决,问了一个同行群,发现可以使用Git gc清理仓库,一瞬间像是打开了新世界的大门,我居然从来不知道Git Gc……….....为了演示这点,往 test 仓库中加入一个大文件,然后在下次提交时将它删除,接着找到并将这个文件从仓库中永久删除。...而在这次提交之前仅用了 2K 左右 ── 显然在这次提交时删除文件并没有真正将其从历史记录中删除。...git.tbz2 接下来要将该文件从历史记录的所有 tree 中移除。...从 size 值可以看出大文件对象还在松散对象中,其实并没有消失,不过这没有关系,重要的是在再进行推送或复制,这个对象不会再传送出去。

    7K20

    化繁为简的企业级 Git 管理实战(五):二进制大文件的版本控制

    我所选择的扩展就是由 Github 团队开发的 Git-LFS 。 Git-LFS 的原理并不复杂:大文件不再支持添加到仓库中,而是存储到另外的 LFS 服务器上。仓库中只保留这些文件的文本链接。...file"$ git push origin master 要注意的是,这个改造过程只会把当前这次 commit 的指定类型文件改成用 LFS 才存储,而不会影响所有历史记录。...由图可以看出,重新创建的这个仓库,把大部分的二进制大文件都改用了 LFS 来存储,整个仓库的大小从 1G 减小到 3M 不到! 测试对这个新的仓库进行克隆,由于本身仓库很小,一下子就克隆下来了。...Git-LFS 的踩坑之旅 虽然 Git-LFS 很好地解决了大文件的版本控制问题,但实际应用到实际团队中时也不见得能顺风顺水。在我将它推广到团队的项目中时,就遇到了几个水土不服的问题。...仔细观察这些二进制文件,我发现它们的大小全部都在 130 字节左右,这意味着这些文件全都没有被恢复。 不幸的是,由于下载下来的内容不再是个 Git 仓库,这些链接文件已无法恢复成实际的文件内容。

    1.9K70

    如何存储 Git 大文件?

    当你推送新的提交到服务器时,新推送的提交引用的所有 Git LFS 文件都会从本地 Git LFS 缓存传输到绑定到 Git 仓库的远程 Git LFS 存储(即 LFS 文件内容会直接从本地 Git...当你 checkout 一个包含 Git LFS 指针的提交时,指针文件将替换为本地 Git LFS 缓存中的文件,或者从远端 Git LFS 存储区下载。...关于 LFS 的指针文件: LFS 的指针文件是一个文本文件,存储在 Git 仓库中,对应大文件的内容存储在 LFS 服务器里,而不是 Git 仓库中,下面为一个图片 LFS 文件的指针文件内容: version...prune 命令从本地 Git LFS 缓存中删除文件: $ git lfs prune ✔ 4 local objects, 33 retained Pruning 4 files, (2.1 MB)...从服务器删除远端 Git LFS 文件 Git LFS 命令行客户端不支持删除服务器上的文件,因此如何删除他们取决于你的托管服务提供商。

    3.6K52

    从仓库中移除敏感信息

    如果你将敏感数据(如密码或 SSH 密钥)提交到 Git 仓库,你能够将其从历史记录中删除。...你无法对仓库中的现有克隆或分支做任何事情,但可以通过联系 GitHub 支持,永久删除所有存储库的缓存视图并在GitHub上提出请求。...如果你的历史记录中尚未拥有敏感数据的存储库本地副本,请将克隆仓库到本地 电脑。...仔细检查你是否已经从仓库的历史记录中删除了你想要的所有内容,并检查了所有分支。 6....告诉你的同事 rebase 而不是 merge 它们创建的任何分支,这些分支是从旧的(受污染的)存储库历史中创建的。一次合并提交可能会重新引入一些或所有你刚才去除清除问题的受污染历史记录。

    96620

    Git 维护及数据恢复

    不过如果有人在某个时刻往项目中添加了一个非常大的文件,那们即便他在后来的提交中将此文件删掉了,所有的签出都会下载这个大文件。因为历史记录中引用了这个文件,它会一直存在着。...为了演示这点,往 test 仓库中加入一个大文件,然后在下次提交时将它删除,接着找到并将这个文件从仓库中永久删除。...而在这次提交之前仅用了 2K 左右 ── 显然在这次提交时删除文件并没有真正将其从历史记录中删除。...git.tbz2 接下来要将该文件从历史记录的所有 tree 中移除。...从 size 值可以看出大文件对象还在松散对象中,其实并没有消失,不过这没有关系,重要的是在再进行推送或复制,这个对象不会再传送出去。

    59420

    Github又悄悄升级了,这次的变化是大文件的存储方式

    在我的个人github网站上,之前在做JAVA NIO demo的时候上传了一个自制的大文件,最近对这个项目进行了一些修改,但是却上传不上github网站了,查看报错的原因,就是说项目中有一个大文件无法上传...LFS和它的安装 LFS的全称是Git Large File Storage,可以将库中的大文件存储在远程服务器比如GitHub.com或者GitHub Enterprise上,在库中保存的是指向这些大文件的链接...从LFS中删除文件 上面我们讲解了如何将文件添加到LFS中进行跟踪,如果我们不想使用LFS而是使用传统的git来管理文件该怎么办呢?...lfs提供了untrack的命令,它是和track相反的命令如下: git lfs untrack "*file-type" 在untrack之后,还要记得从git cache中删除这个文件: git..." to git from lfs" 从LFS中拉取代码 从LFS中拉取代码和传统的普通的git拉取代码是一致的,直接使用git clone命令即可: git clone https://github.com

    97410

    可能每天都会用到的Git命令速查表

    因此,这是同步叉子的方法: 1、添加一个远程仓库 从分支的位置获取上游(主)存储库的地址。...要将文件从Git跟踪中删除并保留在系统中,只需执行以下操作: git reset && echo >> .gitignore 提交后添加到提交中 如果要更改提交消息或向其中添加新文件...从Git删除文件并修剪其整个历史记录 如果你曾经将敏感数据推送到远程存储库(例如,在GitHub上),则不仅需要从Git跟踪中删除文件,还需要删除其整个历史记录。...这样做的过程并不是最简单的,但是GitHub已经编写了一个整页的教程,因此我认为我应该在这里链接它。 "从存储库中删除敏感数据-GitHub"。...这在测试中很常见,例如,由于一项与你的工作完全无关的测试而无法通过时。 在这种情况下,要查找"不良"提交,可以使用git bisect。

    1.2K30

    Git: 掉坑记 -- git reset 杀手

    掉坑起因 解决方法 掉坑起因 项目修改完成之后,会依赖一个比较大的文件,所以这个大文件就在项目根目录中,使用 git 的时候,直接 git add、git commit、git push 一键三连,等到...由于技术太菜,经过谷哥和度娘的帮助下,我成功通过以下命令回撤了版本: # 1、查看提交日志 git log # 2、选择提交id后 git reset --hard id 然后,一看本地项目,卧*,被删的一干二净...,然后在仔细看到别的博客中说到,这个命令之后,本地文件会被删除,需要谨慎使用。...,上面这些内容只是解决了如何恢复已经commit后删除的内容,但是没有解决之前大文件的问题,这里进行 push 的话还是会不行,所以我们需要进行下面操作: # 1、找到你的大文件, 显示10个最大的文件...就是你的大文件 git log --pretty=oneline --branches -- your_file # 4、删除文件历史记录 git filter-branch -f --prune-empty

    70030
    领券