Git回退代碼到某次commit的實現(xiàn)方法
前言
工作中,Git的使用越來越頻繁。。除了最常用的clone
,add
,commit
,push
,pull
等命令;還有回退命令reset
。這一篇博客就記錄一下該回退命令的簡單使用。
場景
因為公司開發(fā)過程中,處理訂單,限時購買等業(yè)務(wù)時,都是用的阿里云的消息隊列MQ實現(xiàn)的?;蛘呤莾蓚€系統(tǒng)之間的交互,同步信息,如用戶在支付系統(tǒng)A
下了一個訂單(支付成功),這個時候支付系統(tǒng)A
除了處理訂單,還有向庫存系統(tǒng)B
發(fā)送一個消息,告知庫存系統(tǒng)B
要減少下單商品的庫存。
我本地跑項目的時候,如果不注釋掉監(jiān)聽器
,測試服上的消息也可能會發(fā)送到我本地,導(dǎo)致消息丟失。
然后~~我就把本地的監(jiān)聽器那一段代碼注釋掉,方便測試人員在測試服上進行測試。注釋掉代碼如下圖:
哈哈~~注釋掉后,提交的時候,被我一起提交了!真是尷尬呢!測試人員說出bug了!
一看代碼提交歷史~~消息監(jiān)聽器被我注釋掉了。這個鍋我背?。ㄐ蓿?/p>
解決問題
哎呀。。。上面說的好像跟這篇文章要說的不太對的上。
其實是開發(fā)中,我不小心把不該提交的代碼提交到了本地,例如TaskListener
這個類,改了之后,不能提交,一不小心被我commit到了本地(還沒有推送到遠程)。
有可能已經(jīng)commit了多次到本地。
1. 先查看commit日志 執(zhí)行下面命令
git log
2. 回滾、取消之前的提交
這里我們假設(shè)應(yīng)該回滾到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
能不能找到這一次提交。
總結(jié)
開發(fā)過程中,總是會不小心提交一些不能提交的文件。。如果你開發(fā)用的IDEA,可以看看IDEA的這個功能—實用,再也不用擔心提交錯了。
到此這篇關(guān)于Git回退代碼到某次commit的實現(xiàn)方法的文章就介紹到這了,更多相關(guān)Git回退代碼到某次commit內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
算法系列15天速成——第十五天 圖【下】(大結(jié)局)
今天是大結(jié)局,說下“圖”的最后一點東西,“最小生成樹“和”最短路徑“2013-11-11詳解phpstudy linux web面板(小皮面板)V0.2版本正式發(fā)布
小皮面板,是由phpStudy官方團隊針對Linux服務(wù)器開發(fā)推出的一款服務(wù)器環(huán)境搭建以及管理工具。這篇文章主要介紹了phpstudy linux web面板(小皮面板)V0.2版本正式發(fā)布,需要的朋友可以參考下2019-10-10fiddler使用方法之Fiddler顯示IP,Fiddler中文亂碼解決方法以及fiddler模擬發(fā)送get/post
今天為大家介紹fiddler的3種使用技巧,(1)Fiddler抓包顯示域名IP(2)解決Fiddler抓包時中文亂碼問題(3)利用fiddler模擬發(fā)送get/post請求的方法2018-10-10idea中的project、module、artifact的具體使用
本文主要介紹了idea中的project、module、artifact的具體使用,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02