先说今天遇到的问题,看到一个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会解决这个问题。