应用场景说明:
在开发中,通常会保持一个主分支 master,及多个 dev 分支,但是因为 dev 分支的开发周期过长,迭代太多而没有及时维护 master ,导致后来发版上线的大部分代码都在 dev 分支上,如果将代码在 master 分支合并会导致很多冲突,最后想丢弃原始 master 分支上的代码,直接将已经测试确认过的 dev 分支强行覆盖到 master 上,并且保留前期的开发提交 git 记录,该如何操作呢?
注意事项:
考虑到安全问题,应提前和同事领导沟通方案。
一般情况下 master 分支是受保护分支,需要拥有该服务的 Maintainer 权限。
具体操作步骤
1、关闭 git 仓库的 master 分支保护
setting => repository => protectd branch => master 【unprotected】
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 分支重新进行保护
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
2014-05-23 判断移动设备访问自动跳转到移动版页面
2013-05-23 java版sqlhelper(转)
2013-05-23 java 连接SQLServer No suitable driver found for jdbc
2013-05-23 Eclipse 连接 SQL Server 2012数据库 (支持jre1.7)(转)