日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

Git遠程刪除某個歷史提交記錄方法詳解_相關技巧

作者:天問 ? 更新時間: 2022-08-22 編程語言

引言

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

分兩種情況:

一、刪除最后一次提交

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

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

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

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

假定: 現在我們要刪除commit--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就沒有了。

原文鏈接:https://www.jianshu.com/p/18b5cbc3e702

欄目分類
最近更新