使用背景
目前这家公司有 dev,test两个分支。
我接到新需求,于是建了新的业务分支 branch1。因为需要和前端联调需要把接口发布到开发环境,然后就把 branch1 的分支合并到 dev 分支。并且 push 到仓库了。
可是,据了解,另外一个高级同事说他也在dev开发,可是联调在test。。。导致test环境会因为没有新需求相关表而报错。
解决办法
如果您需要撤销已经合并到远程分支的提交,可以考虑以下步骤:
- 首先使用
git log
查看要回滚的提交记录,找到需要回滚的 commit id。
* c0416c40 (origin/dev) Merge branch 'xxx_20230730' into dev
|\
| * 67464d72 (origin/xxx_20230730, xxx_20230730) [update] xxx
| * 309fb501 [feature] xxx
| * efb6c81a [feature] xxx
| * 7cd1c383 [feature] xxx
commit id = c0416c40
- 然后使用
git revert
命令回滚合并提交,如下所示:
git revert -m 1 c0416c40
其中 -m 1
用于指定要回滚的提交是主分支(master)的一次合并提交。
我是将含有 Merge branch 字眼的提交分支撤销了,也就是c0416c40。这个操作会删除该提交分支提交的相关文件
- 完成上述步骤后,使用
git push
命令将回滚操作推送到远程分支上。注意,此处可能需要使用强制推送选项-f
,具体命令为:
git push -f origin <branch-name>
其中 <branch-name>
是您想要回滚的远程分支的名称。
- 最后,通知其他开发者关于您对远程分支进行了撤销操作的更改,以便他们在本地分支上拉取最新更改。
结果就是提交历史会增加一行说明
* dabb039c (HEAD -> dev) Revert "Merge branch 'xxx_20230730' into dev"