怎么使用Git远程删除某个历史提交记录

这篇文章主要介绍“怎么使用Git远程删除某个历史提交记录”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用Git远程删除某个历史提交记录”文章能帮助大家解决问题。

引言

在开发中经常会遇到在本地测试的代码或者隐私信息,一不小心提交到了远程仓库,即便立即删除了再提交,但是上次的提交记录在远程依旧可以查看。 特别是像账号密码、key文件这种,很可能造成隐私泄露。

怎么使用Git远程删除某个历史提交记录  git 小火箭节点购买 第1张

分两种情况:

一、删除最后一次提交

这种情况比较简单,主要操作分两步:

  • 第一步:回滚上一次提交

git reset --hard HEAD^
  • 第二步:强制提交本地代码

git push origin master -f

由于本地reset之后本地库落后于远程几个版本,所以需要使用-f强制提交。

二、删除指定commit提交(非最后一次提交)

假定: 现在我们要删除commit--2这条提交记录

图例

怎么使用Git远程删除某个历史提交记录  git 小火箭节点购买 第2张

  • 第一步:查看提交日志,获取要删除记录commit--2的前一次提交commit--1的提交ID

特别提示: rebase -i的ID一定是删除记录的前一次的提交ID

git reflog

展示如下内容:

b08ec3f HEAD@{4}: commit: commit--3
39841d1 HEAD@{5}: commit: commit--2
35f96e1 HEAD@{6}: commit: commit--1

拿到对应的提交ID为35f96e1

  • 第二步:rebase操作

git rebase -i 35f96e1
  • 执行完这个命令后,就可以看到 35f96e1 后的所有 commit 记录。如下图

  • 默认是使用 vim 编辑器打开了commit log list。然后我们就可以针对我们不需要的某些 log 进行删除。

  • 把原本的 pick 单词修改为 drop 就表示该ID对应的 commit log 我们需要删除。

  • vim保存退出。

  • 第三步:解决冲突,强制推送更新到远程

git add .                   # 冲突时使用
git commit -m "new commit"  # 冲突时使用
git rebase --continue       # 冲突时使用
git push origin master -f

再查看远程的提交记录,发现commit--2就没有了。

关于“怎么使用Git远程删除某个历史提交记录”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注蜗牛博客行业资讯频道,小编每天都会为大家更新不同的知识点。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:niceseo99@gmail.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

评论

有免费节点资源,我们会通知你!加入纸飞机订阅群

×
天气预报查看日历分享网页手机扫码留言评论Telegram