Git 学习文档 [四]

引子

接上篇,主要讲 Git 版本回退

谈一谈GIT的后悔药怎么吃

本地分支版本回退的方法

获取要回退的版本号 Commit ID

1
$ git log

或者

1
$ gitk

查找到你要的 commitID

执行回退操作

1
$ git reset --hard <commitID>

如果回退操作执行了,然后你又后悔了

找不到新版本怎么办?,找不到新版本的 commitID 怎么办

在Git中,总是有后悔药可以吃的。
当你用$ git reset –hard commitID回退版本时,再想恢复,就必须找到新版本的 commitID。
Git提供了一个命令

1
git reflog

用来记录你的每一次命令:

1
2
3
4
5
$ git reflog
ea34578 HEAD@{0}: reset: moving to HEAD^
3628164 HEAD@{1}: commit: append GPL
ea34578 HEAD@{2}: commit: add distributed
cb926e7 HEAD@{3}: commit (initial): wrote a readme file

这样就可以找回你要的CommitID了

如果想要回退个人远程仓库的版本怎么办?

如果你的错误提交已经推送到自己的远程分支了,那么就需要回滚远程分支了。
首先要回退本地分支:

1
$ git reset --hard <commitID>

紧接着强制推送到远程分支:

1
$ git push -f

如果要回退公共远程仓库怎么办?

公共远程仓库和个人远程仓库有什么不一样呢 ?

回退公共远程仓库可能会导致将别人的提交丢掉

这里有两个问题

问题1:

回退导致其他人的提交丢失

问题2:

其他小伙伴在回退前,将本地仓库更新到最新,等你回退版本后,又将版本推到回退前的版本了

这里要使用一个新的命令

1
git revert

git revert 会撤销某次提交,虽然代码回退了,但是版本依然是向前的,所以,当使用revert 回退以后,所有人pull之后,他们的代码也自动回退

  1. revert 是撤销一次提交,所以后面的commit id是你需要回滚到的版本的前一次提交
  2. 使用revert HEAD是撤销最近的一次提交,如果你最近一次提交是用revert命令产生的,那么你再执行一次,就相当于撤销了上次的撤销操作,换句话说,你连续执行两次revert HEAD命令,就跟没执行是一样的
  3. 使用revert HEAD~1 表示撤销最近2次提交,这个数字是从0开始的,如果你之前撤销过产生了commit id,那么也会计算在内的。
  4. 如果使用 revert 撤销的不是最近一次提交,那么一定会有代码冲突,需要你合并代码,合并代码只需要把当前的代码全部去掉,保留之前版本的代码就可以了.

git revert 命令的好处就是不会丢掉别人的提交,即使你撤销后覆盖了别人的提交,他更新代码后,可以在本地用 reset 向前回滚,找到自己的代码,然后拉一下分支,再回来合并上去就可以找回被你覆盖的提交了。

比较粗暴的回滚

  1. 本地分支回退到正确的版本,将正确的代码拷贝出来备份
  2. 分支更新到最新,将分支下代码全部删除,将那份新代码放进去
  3. 提交,推送到远程

将某个 文件/文件夹 回滚到某个版本

1
git checkout <commitID> filename/dirname

总结

  1. 自己的分支回滚直接用reset
  2. 公共分支回滚用revert
  3. 错的太远了直接将代码全部删掉,用正确代码替代