Git - 强制替换覆盖 master 分支解决方案

问题描述

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

解决方案

1、关闭 git 仓库的 master 分支保护

setting => repository => protectd branch => master(unprotected)

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

bash 复制代码
git checkout dev

git pull origin dev

3、将当前 dev 分支强行推送到远程 master 主分支进行覆盖

bash 复制代码
git push origin dev:master -f

4、把 head 指向 master 最新版本

bash 复制代码
git reset --hard origin/master

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

  • 此时回到 git 仓库去看 master 分支的代码和 dev 分支的代码就完全一样了
相关推荐
opentrending13 分钟前
Github 热点项目 awesome-mcp-servers MCP 服务器合集,3分钟实现AI模型自由操控万物!
服务器·人工智能·github
乄bluefox2 小时前
解决GitLab无法拉取项目
gitlab
互联网搬砖老肖3 小时前
Git Fetch 和 Git Pull 的区别
git
涛ing3 小时前
【Git “fetch“ 命令详解】
linux·c语言·c++·人工智能·git·vscode·svn
uhakadotcom4 小时前
Thrift2: HBase 多语言访问的利器
后端·面试·github
uhakadotcom5 小时前
轻松掌握XXL-JOB:分布式任务调度的利器
后端·面试·github
ACGkaka_6 小时前
Git(八)如何在同一台电脑登录两个Git
git
Galerkin码农选手7 小时前
github合并多个commit message以及rebase解决文件冲突
github
hac13228 小时前
利用GitHub Pages快速部署前端框架静态网页
前端框架·github
漫天转悠10 小时前
本地Git仓库SSH同步到Gitee(码云)仓库的完整指南(附:SourceTree同步仓库)
git·gitee·ssh