git从特定提交中删除文件

问题描述

我必须从上一次提交中删除一个文件,我已经从上一次提交和master分支中删除了该文件,但是该文件仍然从不同的提交中显示出来

 https://github.com/username/repo/blob/ccf60c8e811d911565e5f88e454dd85e45d89d1e/.env

但是我已经从master分支中删除了.env文件。

我在本地尝试了以下命令-

git filter-branch --index-filter 'git rm --cached --ignore-unmatch .env' -- --all

输出在下面列出-

 Rewrite 83586a63ecb950c5262c851dbbfd521ef5ec8a65 (95/97) (4 seconds passed,remaining 0 predicted)    
 WARNING: Ref 'refs/heads/feature/dependencies' is unchanged
 WARNING: Ref 'refs/heads/master' is unchanged
 WARNING: Ref 'refs/heads/mff1' is unchanged
 WARNING: Ref 'refs/remotes/origin/master' is unchanged
 WARNING: Ref 'refs/remotes/origin/mff1' is unchanged
 WARNING: Ref 'refs/stash' is unchanged 

.env文件仍显示在该链接之后-

 https://github.com/username/repo/blob/ccf60c8e811d911565e5f88e454dd85e45d89d1e/.env

第二次尝试-

比我用

 git obliterate .env

它重写了所有提交,但仍然无法从存储库中删除.env文件。

请指导我如何删除该文件?

谢谢...

解决方法

默认情况下,git不会立即删除未引用的Blob;您需要在存储库的目标副本上触发垃圾回收(git gc)。

(我正在搜索github文档,以查看如何在存储库上触发此操作,这将是存储库管理员可用的操作;其他服务器(如gitlab)将其称为“整理”

[edit]不能一目了然,请联系github的技术支持

您可以问的一个问题是:“您能在我的仓库中运行git gc吗?” )


无论如何,
如果有任何秘密被推送到该存储库,则这些秘密已被发布

您应该撤消这些秘密并创建新的秘密(例如:更改密码,生成新密钥等)。

,

您实际上不能删除提交。您只能添加提交。

假设您有一个现有的Git存储库,其中包含10个提交(十个提交中的每个都有很大的丑陋哈希ID)。十个提交中的最后五个中有一个名为bad的文件。为了简化对存储库的讨论,我们假设这十个提交是由一个主分支(名为mastermain或其他名称)找到的,没有其他分支名称。

如果使用git filter-branch“删除”名为bad的错误文件,则得到的是一个具有 15 个提交的存储库。 15个提交中有10个缺少名为bad的文件,而15个提交中有5个拥有名为bad的文件。这些是之前的五次提交!我们所做的就是添加五个新的和改进的提交;错误的提交仍然存在。

您将从主分支中的 last 提交(无论其名称如何)开始找到的提交,向后工作将是十个 good 提交。很难找到五个 bad 提交:找到它们的唯一方法是使用这五个错误提交中的任何一个的原始哈希ID,例如,通过更早地保存哈希ID。使用其中具有原始哈希ID的GitHub URL视为使用哈希ID:您以这种方式找到提交。

您现在可以将更新的提交(使用--force推送到GitHub,但这只会将五个 good 提交添加到GitHub上的存储库中。该存储库现在将包含所有十五个提交。

这就是您现在正在做的。 “删除”错误的提交实际上并不会删除。最终,那些提交(如果无法找到)将消失。或者,您可以让GitHub支持更快地将其删除。但是保存原始哈希ID的任何人都可以取回文件,直到GitHub最终删除提交为止。

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...