先說今天遇到的問題,看到乙個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會解決這個問題。
Git版本回退
1 檢視檔案修改歷史 git log 返回的是commit後的操作記錄 git log pretty oneline 也可以使用這個命令格式化日誌輸出 2 版本回退 git reset hard head 回退到上乙個版本 git reset hard head 100 會退到第100個版本,例如現...
git版本回退
把修改後的版本通過命令提交到版本庫 第一步 git add 檔名 字尾 第二步 git commit m commit id 但是有時候想回去怎麼辦呢?當然萬能的git給我們提供了方法的。我們先檢視一下最近到最遠的提交紀錄操作如下 在命令航輸入 git log 會顯示提交日誌,但是嫌輸出過多怎麼辦,...
git版本回退
版本回退說白了就是返回某一次操作前的狀態。首先在新建的readme.txt裡輸入內容並已經提交的基礎上執行以下操作 先修改readme.txt文件 gitisa distributed version control system.git isfree software distributed un...