git使用revert撤销已提交的远程合并

使用背景

目前这家公司有 devtest两个分支。

我接到新需求,于是建了新的业务分支 branch1。因为需要和前端联调需要把接口发布到开发环境,然后就把 branch1 的分支合并到 dev 分支。并且 push 到仓库了。

可是,据了解,另外一个高级同事说他也在dev开发,可是联调在test。。。导致test环境会因为没有新需求相关表而报错。

解决办法

如果您需要撤销已经合并到远程分支的提交,可以考虑以下步骤:

  1. 首先使用 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

  1. 然后使用 git revert 命令回滚合并提交,如下所示:
git revert -m 1 c0416c40

其中 -m 1 用于指定要回滚的提交是主分支(master)的一次合并提交。

我是将含有 Merge branch 字眼的提交分支撤销了,也就是c0416c40。这个操作会删除该提交分支提交的相关文件

  1. 完成上述步骤后,使用 git push 命令将回滚操作推送到远程分支上。注意,此处可能需要使用强制推送选项 -f,具体命令为:
git push -f origin <branch-name>

其中 <branch-name> 是您想要回滚的远程分支的名称。

  1. 最后,通知其他开发者关于您对远程分支进行了撤销操作的更改,以便他们在本地分支上拉取最新更改。

结果就是提交历史会增加一行说明

* dabb039c (HEAD -> dev) Revert "Merge branch 'xxx_20230730' into dev"
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值