Git恢复之前版本的三种方法之reset、revert、rebase详解

 更新时间:2023年06月21日 11:09:19   作者:小鸟__老鹰  
这篇文章主要介绍了Git恢复之前版本的三种方法之reset、revert、rebase解读,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

一. 问题描述

在利用github实现多人合作程序开发的过程中,我们有时会出现错误提交的情况,此时我们希望能撤销提交操作,让程序回到提交前的样子

本文总结了三种解决方法:

  • 回退(reset)
  • 反做(revert)
  • 回扣(rebase)

二. 解决方案

方法一:git reset

原理: git reset的作用是修改HEAD的位置,即将HEAD指向的位置改变为之前存在的某个版本

具体实现:

  • 查看版本号 使用命令“git log”查看:
  • 使用“git reset --hard 目标版本号”命令将版本回退:
  • 再用“git log”查看版本信息,此时本地的HEAD已经指向之前的版本:
  • 使用“git push -f”提交到远程更改
  • 注意: 此时如果用“git push”会报错,因为我们本地库HEAD指向的版本比远程库的要旧

方法二:git revert

原理:

git revert是用于“反做”某一个版本,以达到撤销该版本的修改的目的。

比如,我们commit了三个版本(版本一、版本二、 版本三),突然发现版本二不行(如:有bug),想要撤销版本二,但又不想影响撤销版本三的提交,就可以用 git revert 命令来反做版本二,生成新的版本四,这个版本四里会保留版本三的东西,但撤销了版本二的东西。

适用场景

如果我们想撤销之前的某一版本,但是又想保留该目标版本后面的版本,记录下这整个版本变动流程,就可以用这种方法。

具体实现:

1.查看 使用命令“git log”查看commit提交记录

2.使用“git revert 版本号”反做,并使用“git commit -m 版本名”提交

3.使用“git push”推上远程库

方法三:git rebase -i (commit-id) 或 git rebase -i HEAD~(回退几步)

1.查看 使用命令“git log”查看commit提交记录

2.git rebase -i (commit-id) 选择回退版本之前的一次commit版本

3.编辑文件命令行输入 a,切换到编辑模式 将要删除的commit之前的 pick 单词改为drop

4.按下Esc(退出)键 命令行输入 :wq 保存文件退出

5.使用“git push -f”提交到远程更改

6.在使用 git rebase -i (commit-id) 过程中若撤销回退可以使用 git rebase --abort 撤回

若在 git rebase后出现(xxx|REBASE-i)这种情况

原因:用git推送数据到仓库的时候会出现推送失败

解决方案: 使用git rebase --abort 代码回退 回到git rebase之前的状态

其他操作

一. 当代码库远程迁移后,修改本地代码关联到远程地址

1.迁移前先查看当前代码库的远程地址

git remote -v 查看远程地址

2.修改本地代码关联到的远程地址

git remote set-url origin [远程地址]

3.查看当前代码库的远程地址是否修改成功

git remote -v 查看远程地址

4.将本地的master分支推送到origin主机

①指定origin为默认主机 ,后面就可以不加任何参数使用git push

 git push -u origin master  

② 提交本地test分支 作为 远程的master分支 ,不指定默认主机

git push origin test:master

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 教你JVM怎么使用native memory

    教你JVM怎么使用native memory

    这篇文章主要为大家介绍了JVM怎么使用native memory原理详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • wap开发中如何有效的利用缓存减少消息的传送量

    wap开发中如何有效的利用缓存减少消息的传送量

    由于WAP信道带宽的限制,我们在编写WAP应用的时候都希望最大限度地减少消息的传送量。
    2010-06-06
  • 编写高质量代码的30条黄金守则(首选隐式类型转换)

    编写高质量代码的30条黄金守则(首选隐式类型转换)

    这篇文章主要介绍了编写高质量代码的30条黄金守则(首选隐式类型转换),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • 绑定/约束 (binding)指两个东西之间的关联

    绑定/约束 (binding)指两个东西之间的关联

    绑定/约束 (binding)指两个东西之间的关联。如 名字 与它所代表的事物。又如属性与实体之间的关联,又或者符号与操作之间的关联。
    2011-01-01
  • 详解git基本操作和指令

    详解git基本操作和指令

    这篇文章主要介绍了git基本操作和指令的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2020-11-11
  • VSCode 搭建 x264 源码调试环境的详细步骤

    VSCode 搭建 x264 源码调试环境的详细步骤

    这篇文章主要介绍了VSCode 搭建 x264 源码调试环境的详细步骤,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-10-10
  • npm script 的文件监听和自动刷新的命令详解

    npm script 的文件监听和自动刷新的命令详解

    文件监听的作用是为了实现自动化,释放双手和精力,提高效率,让开发者更加关注于开发。这篇文章主要介绍了npm script 的文件监听和自动刷新,需要的朋友可以参考下
    2019-06-06
  • vscode设置多行展示文件标签的操作方法

    vscode设置多行展示文件标签的操作方法

    这篇文章主要给大家介绍了vscode设置多行展示文件标签的操作方法,文中通过图文结合的方式给大家介绍的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2023-12-12
  • 使用TeXLive2022和VSCode安装配置步骤(LaTeX写论文)

    使用TeXLive2022和VSCode安装配置步骤(LaTeX写论文)

    这篇文章主要介绍了使用TeXLive2022和VSCode的安装配置步骤,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-07-07
  • VSCode 云同步扩展设置Settings Sync插件

    VSCode 云同步扩展设置Settings Sync插件

    这篇文章主要介绍了VSCode 云同步扩展设置Settings Sync插件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-05-05

最新评论