Git刪除遠程某個歷史提交記錄

在開發(fā)中經(jīng)常會遇到在本地測試的代碼或者隱私信息,一不小心提交到了遠程倉庫,即便立即刪除了再提交,但是上次的提交記錄在遠程依舊可以查看。 特別是像賬號密碼、key文件這種,很可能造成隱私泄露。

Git

分兩種情況:

一、刪除最后一次提交

這種情況比較簡單,主要操作分兩步:

  • 第一步:回滾上一次提交
git reset --hard HEAD^
  • 第二步:強制提交本地代碼
git push origin master -f

由于本地reset之后本地庫落后于遠程幾個版本,所以需要使用-f強制提交。

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

圖例:
[圖片上傳失敗...(image-8c55ec-1629451481446)]

假定: 現(xiàn)在我們要刪除commit--2這條提交記錄

  1. 第一步:查看提交日志,獲取要刪除記錄commit--2前一次提交commit--1的提交ID

特別提示: rebase -i的ID一定是刪除記錄的前一次的提交ID

git reflog

展示如下內(nèi)容:

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

拿到對應(yīng)的提交ID為35f96e1

  1. 第二步:rebase操作
git rebase -i 35f96e1
  • 執(zhí)行完這個命令后,就可以看到 35f96e1 后的所有 commit 記錄。如下圖
  • 默認是使用 vim 編輯器打開了commit log list。然后我們就可以針對我們不需要的某些 log 進行刪除。
  • 把原本的 pick 單詞修改為 drop 就表示該ID對應(yīng)的 commit log 我們需要刪除。
  • vim保存退出。
Git
  1. 第三步:解決沖突,強制推送更新到遠程
git add .                   # 沖突時使用
git commit -m "new commit"  # 沖突時使用
git rebase --continue       # 沖突時使用
git push origin master -f

再查看遠程的提交記錄,發(fā)現(xiàn)commit--2就沒有了。


Git 相關(guān)系列


歡迎訪問:個人博客地址

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容