以此文记录下在IDEA中如何回滚项目历史版本,并提交远程
大致分为两步:
第一步,回滚本地代码;
第二步,回滚远程代码;
首先,我们先来回滚本地代码
按照下图的步骤,获取你要回滚的历史版本的版本号
然后项目根目录右键 Git->Repository->Reset HEAD
Reset Type 有三种:
mixed 默认方式,只保留源码,回退commit和index信息
soft 回退到某个版本,只回退了commit的信息,不会恢复到index file一级。如果还要提交,直接commit
hard 彻底回退,本地源码也会变成上一个版本内容
此时我们选择Hard彻底回退,点击Reset就能将本地代码版本回滚到指定版本。
然后我们开始将回滚的本地代码提交到远程仓库,此时有两种方式:
第一种,直接强制提交,使用git命令提交 git push -f,但是这样会把回滚版本之后的提交记录全部删除,因此不建议这样做。
第二种,用前面我们回滚本地的方式,再次回滚到最新版本。
首先,我们获取到远程分支最新版本的版本号
然后,我们再次Git->Repository->Reset HEAD 这次与之前有些不一样,我们Reset Type采用Mixed方式将源码保留,然后点击Reset。
最后我们发现代码已经是旧版本的代码,并且版本还是最新版本,此时正常提交push后我们的本地和远程代码的回滚就完成了。
参考:https://blog.csdn.net/gomeplus/article/details/78241070
上面的操作基于IDEA工具来进行操作,其底层原理为利用git的tag标签回滚
git tag操作参考:https://blog.csdn.net/fuchaosz/article/details/51698896
我们只在此证明利用Git tag回滚操作与上面的IDEA操作的关系
首先,切换到IDEA的Terminal命令行(也可以是dos命令行,Git Bash命令行),执行下面的命令
注意tag详细信息里面的commit id
我们在看看git的历史提交记录中上面tag提交的那次记录的Revision Number
Revision Number为 b8e7431ac80cc37d315362b7d2968d4940583820,不同人的编号会不一样,但是commit id 与 Revision Number一定是一样的
那么我们之前IDEA操作的也都是通过这种原理来实现的。
转载于:https://blog.csdn.net/weixin_34072637/article/details/92399631