先說今天遇到的問題,看到一個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
Git 的詳細介紹:請點這裡
Git 的下載地址:請點這裡