git 版本回退(reset&revert)

當(dāng)我們項(xiàng)目發(fā)布上線發(fā)現(xiàn)有問題,又無法立馬解決,需要版本回退的時候,應(yīng)該如何處理,選擇revert還是reset。最怕版本回退有沖突,經(jīng)歷幾次及測試以后,終于弄清楚他們之間的差別,下面就簡單來說一下他們的使用方法及差別

reset

首先我們提交三次代碼:

git提交三次

頁面代碼如下:

git三次提交內(nèi)容

現(xiàn)在執(zhí)行reset命令,把代碼回退到4/7第2次提交之前的狀態(tài),命令如下:

git reset --hard HEAD^
reset命令
  • 執(zhí)行命令以后,我們發(fā)現(xiàn)上一次修改的內(nèi)容已經(jīng)丟失,我們再通過命令git log --oneline看一下提交的歷史記錄
reset提交記錄被刪除
  • 我們看到,第3次提交的歷史信息也被刪除了,并且HEAD當(dāng)前處于我們要回退的版本,所以執(zhí)行git reset命令,其實(shí)做了3步操作:
    1:本地代碼回退到指定的版本;
    2:HEAD移到指定的版本;
    3:移除回退版本之前的所有記錄;

  • 按照理論,這個時候我們需要把本地的代碼,再提交一次,然后發(fā)布,才可以達(dá)到版本回退的效果,命令如下:

git commit -a -m"reset以后提交"
git push
gitPush
  • 但是命令行卻提示,有沖突,需要我們執(zhí)行命令git pull拉取一下代碼,這樣一步也說明了git reset命令重置的只是本地的代碼,遠(yuǎn)程的代碼并沒有改變,按照說明,我們再次執(zhí)行git pull

    reset代碼恢復(fù)

  • 當(dāng)我們拉取代碼以后,線上的代碼,又覆蓋了我們本地的代碼,這樣下來,我們貌似無法達(dá)到線上代碼回退的效果。那我們換一種方式,用強(qiáng)制推送到遠(yuǎn)程的方式去覆蓋線上的代碼試試,命令行如下:

 git push -f
force強(qiáng)推
  • 貌似公司有限制,禁止這樣推送到遠(yuǎn)程,也就是用reset達(dá)到線上的代碼版本回退是很難的。為什么呢?因?yàn)?code>reset命令,本質(zhì)上只會重置本地的代碼,并會自動重置線上的代碼,
    git reset命令還包括一系列參數(shù),這些參數(shù)允許你使用最終提交的內(nèi)容更新本地環(huán)境的其他部分。 這些選項(xiàng)包括:

  • hard:重置repository中branch pointer的指向,使用commit的內(nèi)容填充working directory ,以及重置staging area(暫存區(qū)域)。

  • soft:僅重置repository中branch pointer的指向。

  • mixed:(默認(rèn)值)重置repository中branch pointer的指向。重置staging area(暫存區(qū)域)。

使用這些選項(xiàng)在目標(biāo)環(huán)境中非常有用,例如git reset --hard <commit sha1 | reference>。 這會覆蓋您尚未提交的任何本地更改。 實(shí)際上,它會重置(清除)staging area,并使用使用commit的內(nèi)容填充working directory 。 在使用hard選項(xiàng)之前,請確保這是您真正想要做的事情,因?yàn)樵撁顣采w任何未提交的更改。

revert

同樣我們先提交3個版本:

revert之前提交3次

回退到上一個版本,命令行如下:

git revert HEAD
vim進(jìn)入編輯模式
  • 頁面第3次提交的內(nèi)容已經(jīng)清除,同時命令行打開了vim,這個時候,我們需要按下鍵盤的i鍵,進(jìn)入編輯模式,輸入提交說明如下:
revert說明
  • 說明輸入完成以后,按下鍵盤的Esc鍵,退出編輯模式,之后再按下:wq退出并保存編輯的內(nèi)容如下所示:
vim退出
  • 當(dāng)我們再次按下Enter鍵的時候,我們就可以看到如下所示的提交信息
revert說明提交成功
  • 那本地的代碼已經(jīng)回退到指定的版本,那我們再用命令git log --oneline看一下提交的記錄:
revert提交記錄存在
  • 我們看到之前提交的記錄(revert提交3次)還存在,并且新增加了一個提交記錄,就是我們剛剛輸入的版本回退的記錄,同時HEAD指向了我們剛剛的提交版本,這就是說明,git revert做的操作是:在當(dāng)前已有的版本的基礎(chǔ)上,新生成一個提交,并不是把通過移動HEAD到之前的版本來達(dá)到回退的效果,這樣可以保證我們所有提交的記錄都是存在,不會丟失。

  • 然后我們就可以執(zhí)行git push命令,推送代碼到遠(yuǎn)程服務(wù)器:

revert成功

通過,親自操作git resetgit revert我們看到了它們兩個的區(qū)別,git reset適合回退本地代碼,比如,項(xiàng)目我們修改很多以后,發(fā)現(xiàn)想回到最開始的版本。而git revert適合,項(xiàng)目上線以后,發(fā)現(xiàn)有問題,需要版本回退,這個時候,可以基于之前的版本,再創(chuàng)建一個新的提交,重新發(fā)布就可以,而且之前提交的記錄都存在,而git reset是重置的意思,當(dāng)我們執(zhí)行了這個命令以后,不但代碼回退到指定的版本,之前的提交記錄也是會給清除,所以git reset一定到慎重使用,因?yàn)樗鼤斐刹豢苫赝说男Ч?,除非我們知道之前的提交的哈希值才可以?/p>

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容