• Git远程库代码回退


    一、首先认识两个回退过程中很重要的命令

    1、git log
    显示所有提交过的版本信息,不包括已经被删除的 commit 记录和 reset 的操作
    在这里插入图片描述
    空格向下翻页
    b 向上翻页
    q 退出

    git log --pretty=oneline
    在这里插入图片描述
    git log --oneline
    在这里插入图片描述

    2、git reflog
    可以查看所有分支的所有操作记录(包括已经被删除的 commit 记录和 reset 的操作)
    一般用来找出操作记录中的版本号,进行回退

    二、本地分支版本回退

    如果你在本地做了错误提交,那么回退版本的方法很简单
    先用下面命令找到要回退的版本的commit id:

    git reflog 
    
    • 1

    接着回退版本:

    git reset --hard commitID
    
    • 1

    【注意】reset 命令的三个参数对比(用于本地版本回退,很重要)
    git reset xxx : 撤销暂存 会将文件从暂存区撤销到工作区(未被追踪的状态)

    git reset --soft xxx 不删除本地代码变动,不撤销add,撤销commit

    git reset --mixed xxx 不删除本地代码变动,撤销commit,撤销add

    git reset --hard xxx 删除本地代码变动,撤销commit,撤销add

    三、自己的远程分支版本回退

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

    git reflog 
    git reset --hard commitID
    
    • 1
    • 2

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

    git push -f
    
    • 1

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

    四、公共远程分支版本回退的问题

    回滚公共远程分支和回滚自己的远程分支有区别吗?
    一个显而易见的问题:如果你回退公共远程分支,把别人的提交给丢掉了怎么办?

    1、下面来分析:
    假如你的远程master分支情况是这样的: A1–A2–B1
    其中A、B分别代表两个人,A1、A2、B1代表各自的提交。并且所有人的本地分支都已经更新到最新版本,和远程分支一致。

    这个时候你发现A2这次提交有错误,你用reset回滚远程分支master到A1,那么理想状态是你的队友一拉代码git pull,他们的master分支也回滚了,然而现实却是,你的队友会看到下面的提示:

    $ git status
    On branch master
    Your branch is ahead of 'origin/master' by 2 commits.
      (use "git push" to publish your local commits)
    nothing to commit, working directory clean
    
    • 1
    • 2
    • 3
    • 4
    • 5

    也就是说,你的队友的分支并没有主动回退,而是比远程分支超前了两次提交,因为远程分支回退了嘛

    这个时候,你大吼一声:兄弟们,老子回退版本了。如果你的队友都是神之队友,比如: Tony(腾讯CTO),那么Tony会冷静的使用下面的命令来找出你回退版本后覆盖掉的他的提交,也就是B1那次提交:比如tony当前开发的分支是 tony_branch

    git checkout tony_branch        //先回到自己的分支 
    git reflog                      //查看历史提交记录  
    git reset --hard B1             //回到被覆盖的那次提交B1
    git checkout -b tony_backup 
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    通过上面一通敲,Tony暂时舒了一口气,还好,B1那次提交找回来了,这时tony_backup分支最新的一次提交就是B1,接着Tony要把自己的本地master分支和远程master分支保持一致:

    git reset --hard origin/master
    
    • 1

    执行了上面这条命令后,Tony的master分支才真正的回滚了,也就是说你的回滚操作才能对Tony生效,这个时候Tony的本地maser是这样的: A1

    接着Tony要再次合并那个被丢掉的B1提交:

    git checkout master             //切换到master
    git merge tony_backup           //再合并一次带有B1的分支到master
    
    • 1
    • 2

    终于把丢掉的B1给找回来了,接着他push一下,你一拉也能同步。

    2、然而很不幸的是,现实中,我们经常遇到的都是猪一样的队友,他们一看到下面提示:

    $ git status
    On branch master
    Your branch is ahead of 'origin/master' by 2 commits.
      (use "git push" to publish your local commits)
    nothing to commit, working directory clean
    
    • 1
    • 2
    • 3
    • 4
    • 5

    就习惯性的git push一下,这样,你辛辛苦苦回滚的版本就这样轻松的被你猪一样的队友给还原了,所以,只要有一个队友push之后,远程master又变成了 A1 – A2 – B1

    这就是分布式,每个人都有副本。这个时候你连揍他的心都有了,怎么办呢?你不能指望每个人队友都是git高手,下面我们用另外一种方法来回退版本。

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

    使用git reset回退公共远程分支的版本后,需要其他所有人手动用远程master分支覆盖本地master分支,显然,这不是优雅的回退方法,下面我们使用另个一个命令来回退版本:

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

    git revert 命令意思是撤销某次提交。它会产生一个新的提交,虽然代码回退了,但是版本依然是向前的,所以,当你用revert回退之后,所有人pull之后,他们的代码也自动的回退了。
    但是,要注意以下几点:
    1)revert 是撤销一次提交,所以后面的commit id是你需要回滚到的版本的前一次提交
    2)使用revert HEAD是撤销最近的一次提交,如果你最近一次提交是用revert命令产生的,那么你再执行一次,就相当于撤销了上次的撤销操作,换句话说,你连续执行两次revert HEAD命令,就跟没执行是一样的
    3)使用revert HEAD~1 表示撤销最近2次提交,这个数字是从0开始的

  • 相关阅读:
    Unity学习笔记[一] RollBall小游戏
    最新免费毕业论文下载java+ssm
    记LGSVL Map Annotation(3)利用map annotation生成一个十字路口的opendrive格式地图
    设计模式 - 模板模式
    c++模板小例子
    Python内置函数12——map
    高光谱成像技术简介,怎么选择成像方案?
    用unity和c#实现
    Symmetric Encoding(Round 946)
    听说你想面对监狱编程,你,够格吗?
  • 原文地址:https://blog.csdn.net/hc1285653662/article/details/125899254