Git强行替换覆盖master分支

应用场景说明:
在开发中,通常会保持一个主分支 master,及多个 dev 分支,但是因为 dev 分支的开发周期过长,迭代太多而没有及时维护 master ,导致后来发版上线的大部分代码都在 dev 分支上,如果将代码在 master 分支合并会导致很多冲突,最后想丢弃原始 master 分支上的代码,直接将已经测试确认过的 dev 分支强行覆盖到 master 上,并且保留前期的开发提交 git 记录,该如何操作呢?

注意事项:
考虑到安全问题,应提前和同事领导沟通方案。
一般情况下 master 分支是受保护分支,需要拥有该服务的 Maintainer 权限。

具体操作步骤

1、关闭 git 仓库的 master 分支保护
setting => repository => protectd branch => master 【unprotected】
gitlab代码仓库设置

2、切换到 dev 分支,并拉取远程 dev 分支最新代码
git checkout dev
git pull origin dev

3、将当前 dev 分支强行推送到远程 master 主分支进行覆盖
git push origin dev:master -f

4、把 head 指向 master 最新版本
git reset --hard origin/master

5、在 git 仓库中将 master 分支重新进行保护
保护master分支

此时回到 git 仓库去看 master 分支的代码和 dev 分支的代码就完全一样了。

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将一个分支完全覆盖master分支上,可以按照以下步骤进行操作: 1. 首先,切换到master分支:`git checkout master` \[1\] 2. 然后,使用`git reset --hard dev`命令将dev分支的代码完全覆盖master分支上 \[1\] 3. 最后,使用`git push origin master --force`命令强制推送到远程的master分支 \[1\] 需要注意的是,如果被覆盖分支处于受保护状态,执行push操作后会报错。解决这个问题的方法是登录到你的git仓库,找到设置/仓库/保护分支,将需要强制推送的分支取消保护,然后再强制推送完毕后将该分支重新设置为保护状态 \[1\]。 这种操作适用于在开发中,由于dev分支的开发周期过长,导致后来发版上线的大部分代码都在dev分支上,想要丢弃原始master分支上的代码,直接将已经测试确认过的dev分支强行覆盖master上,并且保留前期的开发提交git记录的场景 \[3\]。 #### 引用[.reference_title] - *1* [Git 将一个分支完全覆盖(不是合并)到另一个分支](https://blog.csdn.net/weixin_43239880/article/details/128299485)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Git强行替换覆盖master分支](https://blog.csdn.net/qq_46337973/article/details/128952456)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值