1. 程式人生 > 程式設計 >Git回退程式碼到某次commit的實現方法

Git回退程式碼到某次commit的實現方法

前言

工作中,Git的使用越來越頻繁。。除了最常用的clone,add,commit,push,pull等命令;還有回退命令reset。這一篇部落格就記錄一下該回退命令的簡單使用。

場景

因為公司開發過程中,處理訂單,限時購買等業務時,都是用的阿里雲的訊息佇列MQ實現的。或者是兩個系統之間的互動,同步資訊,如使用者在支付系統A下了一個訂單(支付成功),這個時候支付系統A除了處理訂單,還有向庫存系統B傳送一個訊息,告知庫存系統B要減少下單商品的庫存。

我本地跑專案的時候,如果不註釋掉監聽器,測試服上的訊息也可能會發送到我本地,導致訊息丟失。
然後~~我就把本地的監聽器那一段程式碼註釋掉,方便測試人員在測試服上進行測試。註釋掉程式碼如下圖:

Git回退程式碼到某次commit的實現方法

哈哈~~註釋掉後,提交的時候,被我一起提交了!真是尷尬呢!測試人員說出bug了!

一看程式碼提交歷史~~訊息監聽器被我註釋掉了。這個鍋我背!(笑哭)

解決問題

哎呀。。。上面說的好像跟這篇文章要說的不太對的上。

其實是開發中,我不小心把不該提交的程式碼提交到了本地,例如TaskListener這個類,改了之後,不能提交,一不小心被我commit到了本地(還沒有推送到遠端)。

有可能已經commit了多次到本地。

1. 先檢視commit日誌 執行下面命令

git log

Git回退程式碼到某次commit的實現方法

2. 回滾、取消之前的提交

這裡我們假設應該回滾到239afed0857cc2e77c17c01014077808619af64d

這個版本,及這個版本及之後的commit全部取消。

git reset --hard commit_id  
 //退到/進到 指定commit的sha碼 commit_id:239afed0857cc2e77c17c01014077808619af64d

3.ok,可以重新提交了

git commit a.txt -m "重新提交"  
// 記得不要提交不想提交的檔案哦

IDEA RESET

也可以直接使用IDEA的Reset Head 功能,先通過git log 得到要回退的commit_id,再進行下面截圖的操作。可以先validate一下哦,看通過commit_id能不能找到這一次提交。

Git回退程式碼到某次commit的實現方法

Git回退程式碼到某次commit的實現方法

總結

開發過程中,總是會不小心提交一些不能提交的檔案。。如果你開發用的IDEA,可以看看IDEA的這個功能—實用,再也不用擔心提交錯了。

到此這篇關於Git回退程式碼到某次commit的實現方法的文章就介紹到這了,更多相關Git回退程式碼到某次commit內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!