• 技术文章 >开发工具 >git

    GIT 如何回退到某次 commit ?

    GuanhuiGuanhui2020-07-23 17:57:18转载10165

    前言

    工作中,Git的使用越来越频繁。。除了最常用的clone,add,commit,push,pull等命令;还有回退命令reset。这一篇博客就记录一下该回退命令的简单使用。

    场景

    因为公司开发过程中,处理订单,限时购买等业务时,都是用的阿里云的消息队列MQ实现的。或者是两个系统之间的交互,同步信息,如用户在支付系统A下了一个订单(支付成功),这个时候支付系统A除了处理订单,还有向库存系统B发送一个消息,告知库存系统B要减少下单商品的库存。

    我本地跑项目的时候,如果不注释掉监听器,测试服上的消息也可能会发送到我本地,导致消息丢失。
    然后~~我就把本地的监听器那一段代码注释掉,方便测试人员在测试服上进行测试。注释掉代码如下图:

    哈哈~~注释掉后,提交的时候,被我一起提交了!真是尴尬呢!测试人员说出bug了!

    一看代码提交历史~~消息监听器被我注释掉了。这个锅我背!(笑哭)

    解决问题

    哎呀。。。上面说的好像跟这篇文章要说的不太对的上。

    其实是开发中,我不小心把不该提交的代码提交到了本地,例如TaskListener这个类,改了之后,不能提交,一不小心被我commit到了本地(还没有推送到远程)。

    有可能已经commit了多次到本地。

    1. 先查看commit日志 执行下面命令

    git log


    2. 回滚、取消之前的提交

    这里我们假设应该回滚到239afed0857cc2e77c17c01014077808619af64d这个版本,及这个版本及之后的commit全部取消。

    git reset --hard commit_id  
     //退到/进到 指定commit的sha码 commit_id:239afed0857cc2e77c17c01014077808619af64d

    3.ok,可以重新提交了

    git commit a.txt -m "重新提交"  
    // 记得不要提交不想提交的文件哦

    IDEA RESET

    也可以直接使用IDEA的Reset Head 功能,先通过git log 得到要回退的commit_id,再进行下面截图的操作。可以先validate一下哦,看通过commit_id能不能找到这一次提交。


    总结

    开发过程中,总是会不小心提交一些不能提交的文件。。如果你开发用的IDEA,可以看看IDEA的这个功能—实用,再也不用担心提交错了。

    推荐教程:《Git教程

    以上就是GIT 如何回退到某次 commit ?的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:jb51,如有侵犯,请联系admin@php.cn删除
    专题推荐:git
    上一篇:“git fetch”与“git pull”的区别 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • GIT 和 SVN 区别详解• dockerhub内怎么连接github自动构建镜像?• “git add -A” 和 “git add .” 的区别• GIT 的分支与合并• “git fetch”与“git pull”的区别
    1/1

    PHP中文网