200字范文,内容丰富有趣,生活中的好帮手!
200字范文 > Git版本回退方法

Git版本回退方法

时间:2023-06-14 05:15:44

相关推荐

Git版本回退方法

简介

今天在公司犯了错误,在公司公共的develop分支上push了错误的代码,顺便研究了一下git如何回退版本,参考了大佬的做法,记录下了这篇博客。

问题

如果提交了一个错误的版本,怎么回退版本?

如果提交了一个错误的版本到远程分支,怎么回退远程分支版本?

如果提交了一个错误的版本到公共远程分支,又该怎么回退版本?

本地分支版本回退的方法

如果你在本地做了错误提交,那么回退版本的方法很简单

先用下面命令找到要回退的版本的commit id:

git reflog

接着回退版本:

git reset --hard Obfafd

0bfafd就是你要回退的版本的commit id的前面几位

自己的远程分支版本回退的方法

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

首先要回退本地分支:

git refloggit reset --hard Obfafd

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

git push -f origin develop

注意:本地分支回滚后,版本将落后远程分支,必须使用强制推送覆盖远程分支,否则无法推送到远程分支

公共远程分支版本回退的方法

使用git reset回退公共远程分支的版本后,需要其他所有人手动用远程master分支覆盖本地master分支,

显然,这不是优雅的回退方法,下面我们使用另个一个命令来回退版本:

git revert HEAD //撤销最近一次提交git revert HEAD~1 //撤销上上次的提交,注意:数字从0开始git revert 0ffaacc //撤销0ffaacc这次提交

git revert 命令意思是撤销某次提交。它会产生一个新的提交,虽然代码回退了,但是版本依然是向前的

所以,当你用revert回退之后,所有人pull之后,他们的代码也自动的回退了。

但是,要注意以下几点:

revert 是撤销一次提交,所以后面的commit id是你需要回滚到的版本的前一次提交

使用revert HEAD是撤销最近的一次提交,如果你最近一次提交是用revert命令产生的,那么你再执行一次,就相当于撤销了上次的撤销操作,换句话说,你连续执行两次revert HEAD命令,就跟没执行是一样的

使用revert HEAD~1 表示撤销最近2次提交,这个数字是从0开始的,如果你之前撤销过产生了commi id,那么也会计算在内的。

如果使用 revert 撤销的不是最近一次提交,那么一定会有代码冲突,需要你合并代码,合并代码只需要把当前的代码全部去掉,保留之前版本的代码就可以了.

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

继续扩展,简单粗暴的回滚方法

看到这里也许你已经觉得学会了远程仓库版本回滚方法了,但是实践中总是会遇到很多不按套路来的问题,考虑下面一种情况:

如果你们开发中,忽然发现前面很远的地方有一次错误的合并代码,把本来下一次才能发的功能的代码合并到了这一次来了,这个时候全体成员都觉得直接回滚比较快,因为他们都有备份,覆盖了无所谓,这个时候用reset的话对队友的要求比较高,用revert的话呢要大面积的解决冲突,也很麻烦呀,怎么办呢?

这个时候,可以使用简单粗暴的办法,直接从那个错误的提交的前一次拉取一份代码放到其他目录,然后将master代码全部删除,把那份新代码方进去,然后提交,果然简单粗暴啊,虽然这种方法不入流,但是,实践中发现很好使啊,所以,实践是检验真理的唯一标准。遇到问题还是要灵活应对。

总结

远程分支回滚的三种方法:

自己的分支回滚直接用reset

公共分支回滚用revert

错的太远了直接将代码全部删掉,用正确代码替代

参考资料

/fuchaosz/article/details/52170105

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。