如何解决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
的文件。为了简化对存储库的讨论,我们假设这十个提交是由一个主分支(名为master
或main
或其他名称)找到的,没有其他分支名称。
如果使用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最终删除提交为止。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。