在开发中经常会遇到在本地测试的代码或者隐私信息,一不小心提交到了远程仓库,即便立即删除了再提交,但是上次的提交记录在远程依旧可以查看。 特别是像账号密码、key文件这种,很可能造成隐私泄露。
分两种情况:
这种情况比较简单,主要操作分两步:
git reset --hard HEAD^
git push origin master -f
由于本地reset之后本地库落后于远程几个版本,所以需要使用-f强制提交。
假定: 现在我们要删除commit--2这条提交记录
图例
特别提示: 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
git rebase -i 35f96e1
git add . # 冲突时使用 git commit -m "new commit" # 冲突时使用 git rebase --continue # 冲突时使用 git push origin master -f
再查看远程的提交记录,发现commit--2就没有了。