Git回退代码到某次commit的实现方法

作者:门卫向大爷 时间:2022-07-09 15:08:26 

前言

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

场景

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

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

Git回退代码到某次commit的实现方法

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

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

解决问题

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

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

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

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


git log

Git回退代码到某次commit的实现方法 

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能不能找到这一次提交。

Git回退代码到某次commit的实现方法 

Git回退代码到某次commit的实现方法

总结

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

来源:https://blog.csdn.net/qq_22638399/article/details/80847205

标签:git,还原,commit
0
投稿

猜你喜欢

  • python中itertools模块zip_longest函数详解

    2023-01-02 09:09:35
  • 浅谈Django+Gunicorn+Nginx部署之路

    2023-04-19 16:36:52
  • 浅谈Python接口对json串的处理方法

    2022-07-30 13:03:49
  • 对python使用telnet实现弱密码登录的方法详解

    2023-12-28 02:52:46
  • PHP的mysqli_select_db()函数讲解

    2023-06-07 18:59:44
  • ASP伪造REFERER方法

    2008-07-03 12:48:00
  • Python基于socket模块实现UDP通信功能示例

    2023-08-25 06:45:27
  • MySQL高效分页解决方案集分享

    2024-01-26 09:29:36
  • 微信小程序 滚动选择器(时间日期)详解及实例代码

    2024-01-27 22:57:53
  • vue2/vue3路由权限管理的方法实例

    2024-05-29 22:28:54
  • Python3连接Mysql8.0遇到的问题及处理步骤

    2024-01-20 13:06:46
  • 解决Pycharm调用Turtle时 窗口一闪而过的问题

    2023-05-06 14:46:29
  • 详解Python给照片换底色(蓝底换红底)

    2023-02-03 02:07:45
  • Go语言context上下文管理的使用

    2023-06-16 03:55:26
  • python MysqlDb模块安装及其使用详解

    2024-01-15 15:21:44
  • Oracle故障处理Rman-06207&Rman-06214的方法

    2023-07-08 01:26:29
  • php通过pecl方式安装扩展的实例讲解

    2023-07-23 07:06:12
  • 比较SQL Server约束和DML触发器

    2008-12-24 15:54:00
  • Oracle对两个数据表交集的查询

    2010-07-26 12:51:00
  • asp如何删除数据库中的表或索引?

    2010-06-26 12:23:00
  • asp之家 网络编程 m.aspxhome.com