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

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

Git遠(yuǎn)程刪除某個(gè)歷史提交記錄方法詳解_相關(guān)技巧

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

引言

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

分兩種情況:

一、刪除最后一次提交

這種情況比較簡(jiǎn)單,主要操作分兩步:

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

由于本地reset之后本地庫落后于遠(yuǎn)程幾個(gè)版本,所以需要使用-f強(qiáng)制提交。

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

假定: 現(xiàn)在我們要?jiǎng)h除commit--2這條提交記錄

圖例

  • 第一步:查看提交日志,獲取要?jiǎng)h除記錄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

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

  • 第二步:rebase操作
git rebase -i 35f96e1
  • 執(zhí)行完這個(gè)命令后,就可以看到 35f96e1 后的所有 commit 記錄。如下圖
  • 默認(rèn)是使用 vim 編輯器打開了commit log list。然后我們就可以針對(duì)我們不需要的某些 log 進(jìn)行刪除。
  • 把原本的 pick 單詞修改為 drop 就表示該ID對(duì)應(yīng)的 commit log 我們需要?jiǎng)h除。
  • vim保存退出。

  • 第三步:解決沖突,強(qiáng)制推送更新到遠(yuǎn)程
git add .                   # 沖突時(shí)使用
git commit -m "new commit"  # 沖突時(shí)使用
git rebase --continue       # 沖突時(shí)使用
git push origin master -f

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

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

欄目分類
最近更新