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

Git
分兩種情況:
一、刪除最后一次提交
這種情況比較簡單,主要操作分兩步:
- 第一步:回滾上一次提交
git reset --hard HEAD^
- 第二步:強制提交本地代碼
git push origin master -f
由于本地reset之后本地庫落后于遠程幾個版本,所以需要使用-f強制提交。
二、刪除指定commit提交(非最后一次提交)
圖例:
[圖片上傳失敗...(image-8c55ec-1629451481446)]
假定: 現(xiàn)在我們要刪除commit--2這條提交記錄
- 第一步:查看提交日志,獲取要刪除記錄
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
- 第二步:
rebase操作
git rebase -i 35f96e1
- 執(zhí)行完這個命令后,就可以看到
35f96e1后的所有 commit 記錄。如下圖 - 默認是使用 vim 編輯器打開了commit log list。然后我們就可以針對我們不需要的某些 log 進行刪除。
- 把原本的
pick單詞修改為drop就表示該ID對應(yīng)的 commit log 我們需要刪除。 - vim保存退出。

Git
- 第三步:解決沖突,強制推送更新到遠程
git add . # 沖突時使用
git commit -m "new commit" # 沖突時使用
git rebase --continue # 沖突時使用
git push origin master -f
再查看遠程的提交記錄,發(fā)現(xiàn)commit--2就沒有了。
Git 相關(guān)系列
歡迎訪問:個人博客地址