2021-05-12 14:32:11
Git版本回滾
先說今天遇到的問題,看到一個config.php的組態檔一直在修改的狀態下,但是和遠端的config.php是不一致的,我不需要提交它,但是看它在 modified的狀態下,很不爽,想刪除它,git rm config.php,然後git push了下,結果不僅把原生的config.php幹掉了,把遠端的config.php也給幹掉了,難過,原來這個git rm有這樣的功效,而且我 刪除的不只是這一個檔案,還有n個檔案。
想到要回滾到最近的一次提交。做這個工作前,提醒下,在本地直接把程式碼備份一份,要不之後的操作不當,會直接把你的這次修改全部抹殺掉,到時你哭都來不及;除非你對git有相對的把握,深知任何 一步操作的意義,了解git的 分支機制。
回滾分三步:
(1)備份你當前的程式碼 庫一份,不是必須的操作,但是提醒要 做的,當然有可以用git branch backup 把當前的版本備份到一個新的分支
(2)git log找到要回滾的版本
(3)git reset --hard 要回滾到的版本號,比如 git reset --hard 91deaf(檔案都回來了,包括config.php)
然後git status的時候,可能會提醒你 Your branch is behind 'origin/master' by 2 commits 類似的錯誤,然後提醒你用git pull先下拉。如果你直接git push是推不了的,
因為遠端已經是在你reset後的版本了,也就是說遠端的版本比你reset的版本新,你是reset回滾到老版本的。
但是你git pull後(我用的是git fetch,之後再git merge合併),又會重新把遠端的最新版本庫覆蓋掉原生的老版本,這樣又回到了剛開始的問題。
如果 你在上述回滾三步之後,如果發現 有問題 ,重新切換到備份分支,也回到了剛開始的你原生的操作開始的版本,也就是reset回滾回來的檔案又被刪除了,比如config.php,這點很NB。其實備份分支也就是你當前最新狀態的版本 ,reset後回到了老版本。
那麼到底怎麼解決問題呢?用了一個很笨的辦法,但是目前沒有找到好的方法。
git reset 後,git push -f 強推,如果不帶引數-f是推不了的。
推過之後,再把你這次修改的檔案一個個加上去,git add ,git commit ,git push 完畢。
思考:也許在用git reset --soft會解決這個問題。
GitHub 教學系列文章:
GitHub 使用教學圖文詳解 http://www.linuxidc.com/Linux/2014-09/106230.htm
Git 標籤管理詳解 http://www.linuxidc.com/Linux/2014-09/106231.htm
Git 分支管理詳解 http://www.linuxidc.com/Linux/2014-09/106232.htm
Git 遠端倉庫詳解 http://www.linuxidc.com/Linux/2014-09/106233.htm
Git 本地倉庫(Repository)詳解 http://www.linuxidc.com/Linux/2014-09/106234.htm
Git 伺服器搭建與用戶端安裝 http://www.linuxidc.com/Linux/2014-05/101830.htm
Git 概述 http://www.linuxidc.com/Linux/2014-05/101829.htm
分享實用的GitHub 使用教學 http://www.linuxidc.com/Linux/2014-04/100556.htm
相關文章