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 

Git 的详细介绍请点这里
Git 的下载地址请点这里

发表评论

电子邮件地址不会被公开。 必填项已用*标注