前言
工作中,git的使用越來越頻繁。。除了最常用的clone,add,commit,push,pull等命令;還有回退命令reset。這一篇博客就記錄一下該回退命令的簡單使用。
場景
因為公司開發過程中,處理訂單,限時購買等業務時,都是用的阿里云的消息隊列MQ實現的。或者是兩個系統之間的交互,同步信息,如用戶在支付系統A下了一個訂單(支付成功),這個時候支付系統A除了處理訂單,還有向庫存系統B發送一個消息,告知庫存系統B要減少下單商品的庫存。
我本地跑項目的時候,如果不注釋掉監聽器,測試服上的消息也可能會發送到我本地,導致消息丟失。
然后~~我就把本地的監聽器那一段代碼注釋掉,方便測試人員在測試服上進行測試。注釋掉代碼如下圖:
哈哈~~注釋掉后,提交的時候,被我一起提交了!真是尷尬呢!測試人員說出bug了!
一看代碼提交歷史~~消息監聽器被我注釋掉了。這個鍋我背?。ㄐ蓿?/p>
解決問題
哎呀。。。上面說的好像跟這篇文章要說的不太對的上。
其實是開發中,我不小心把不該提交的代碼提交到了本地,例如TaskListener這個類,改了之后,不能提交,一不小心被我commit到了本地(還沒有推送到遠程)。
有可能已經commit了多次到本地。
1. 先查看commit日志 執行下面命令
git?log
?
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,再進行下面截圖的操作??梢韵葀alidate一下哦,看通過commit_id能不能找到這一次提交。
?
總結
開發過程中,總是會不小心提交一些不能提交的文件。。如果你開發用的IDEA,可以看看IDEA的這個功能—實用,再也不用擔心提交錯了。
推薦教程:《Git教程》