小編給大家分享一下GIT回退到某次commit的方法,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!
創(chuàng)新互聯(lián)建站長(zhǎng)期為成百上千客戶(hù)提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開(kāi)放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為密云企業(yè)提供專(zhuān)業(yè)的成都網(wǎng)站制作、成都網(wǎng)站建設(shè)、外貿(mào)營(yíng)銷(xiāo)網(wǎng)站建設(shè),密云網(wǎng)站改版等技術(shù)服務(wù)。擁有10余年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開(kāi)發(fā)。前言
工作中,Git的使用越來(lái)越頻繁。。除了最常用的clone
,add
,commit
,push
,pull
等命令;還有回退命令reset
。這一篇博客就記錄一下該回退命令的簡(jiǎn)單使用。
場(chǎng)景
因?yàn)楣鹃_(kāi)發(fā)過(guò)程中,處理訂單,限時(shí)購(gòu)買(mǎi)等業(yè)務(wù)時(shí),都是用的阿里云的消息隊(duì)列MQ實(shí)現(xiàn)的?;蛘呤莾蓚€(gè)系統(tǒng)之間的交互,同步信息,如用戶(hù)在支付系統(tǒng)A
下了一個(gè)訂單(支付成功),這個(gè)時(shí)候支付系統(tǒng)A
除了處理訂單,還有向庫(kù)存系統(tǒng)B
發(fā)送一個(gè)消息,告知庫(kù)存系統(tǒng)B
要減少下單商品的庫(kù)存。
我本地跑項(xiàng)目的時(shí)候,如果不注釋掉監(jiān)聽(tīng)器
,測(cè)試服上的消息也可能會(huì)發(fā)送到我本地,導(dǎo)致消息丟失。
然后~~我就把本地的監(jiān)聽(tīng)器那一段代碼注釋掉,方便測(cè)試人員在測(cè)試服上進(jìn)行測(cè)試。注釋掉代碼如下圖:
哈哈~~注釋掉后,提交的時(shí)候,被我一起提交了!真是尷尬呢!測(cè)試人員說(shuō)出bug了!
一看代碼提交歷史~~消息監(jiān)聽(tīng)器被我注釋掉了。這個(gè)鍋我背?。ㄐ蓿?/p>
解決問(wèn)題
哎呀。。。上面說(shuō)的好像跟這篇文章要說(shuō)的不太對(duì)的上。
其實(shí)是開(kāi)發(fā)中,我不小心把不該提交的代碼提交到了本地,例如TaskListener
這個(gè)類(lèi),改了之后,不能提交,一不小心被我commit到了本地(還沒(méi)有推送到遠(yuǎn)程)。
有可能已經(jīng)commit了多次到本地。
1. 先查看commit日志 執(zhí)行下面命令
git log
2. 回滾、取消之前的提交
這里我們假設(shè)應(yīng)該回滾到239afed0857cc2e77c17c01014077808619af64d
這個(gè)版本,及這個(gè)版本及之后的commit全部取消。
git reset --hard commit_id //退到/進(jìn)到 指定commit的sha碼 commit_id:239afed0857cc2e77c17c01014077808619af64d
3.ok,可以重新提交了
git commit a.txt -m "重新提交" // 記得不要提交不想提交的文件哦
IDEA RESET
也可以直接使用IDEA的Reset Head
功能,先通過(guò)git log
得到要回退的commit_id
,再進(jìn)行下面截圖的操作??梢韵葀alidate一下哦,看通過(guò)commit_id
能不能找到這一次提交。
開(kāi)發(fā)過(guò)程中,總是會(huì)不小心提交一些不能提交的文件。。如果你開(kāi)發(fā)用的IDEA,可以看看IDEA的這個(gè)功能—實(shí)用,再也不用擔(dān)心提交錯(cuò)了。
看完了這篇文章,相信你對(duì)GIT回退到某次commit的方法有了一定的了解,想了解更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!