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

2023-12-05 0 791
目录
  • 一. 问题描述
  • 二. 解决方案
    • 方法一:git reset
    • 方法二:git revert
    • 方法三:git rebase -i (commit-id) 或 git rebase -i HEAD~(回退几步)
    • 其他操作
  • 总结

    一. 问题描述

    在利用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恢复之前版本的三种方法之reset、revert、rebase详解

    原因:用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

    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持悠久资源网。

    您可能感兴趣的文章:

    • Git获取本地仓库及基础操作指令总结
    • 详解git reset 加不加 –hard的区别
    • 详解git的基本使用方法

    收藏 (0) 打赏

    感谢您的支持,我会继续努力的!

    打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
    点赞 (0)

    悠久资源 编程技巧 Git恢复之前版本的三种方法之reset、revert、rebase详解 https://www.u-9.cn/biancheng/jiqiao/98772.html

    常见问题

    相关文章

    发表评论
    暂无评论
    官方客服团队

    为您解决烦忧 - 24小时在线 专业服务