合并修改缺陷分支的commit到master分支

合并修改缺陷分支的commit到master分支

当我们在修改缺陷的时候,我们会开辟一个分支,专门用来修改缺陷例如hotfix

当我们在hotfix上commit的代码,想要合并到master分支,这时我们要怎么处理呢

我们使用 git cherry-pick:合并提交节点到其他分支,将指定的提交(commit)应用于其他分支

我们这里使用hotfix和master做举例

javascript 复制代码
git checkout hotfix # 先切换到提交过的那个分支
git log # 查找要合并分支的commit提交值
git checkout master # 切换到要合并的master分支
git cherry-pick <commit_id>

commit_id就是git log查找到的commit id

这样就在master分支上合并了在hotfix中commit的那次提交

cherry pick 支持的其他提交方式

javascript 复制代码
git cherry-pick Dev # 应用Dev分支最新的提交

git cherry-pick <commit_id1> <commit_id2> # 合并commit_id1 和 commit_id2 两次体提交

注意执行git cherry-pick 后 只是将提交合并到本地 需要执行 git push指令 才会将合并commit 提交到远程仓库

报错处理。

如果在cherry-pick的时候出现类似以下错误提示,那可能是是对同一提交重复做cherry-pick引起的。

The previous cherry-pick is now empty, possibly due to conflict resolution.

If you wish to commit it anyway, use:

git commit --allow-empty

Otherwise, please use 'git cherry-pick --skip'

On branch auto-7940289-dev-0b41beba

Your branch is up to date with 'origin/auto-7940289-dev-0b41beba'.

You are currently cherry-picking commit e924fd2.

(all conflicts fixed: run "git cherry-pick --continue")

(use "git cherry-pick --skip" to skip this patch)

(use "git cherry-pick --abort" to cancel the cherry-pick operation)

Error content分析:没有冲突输出,而是提示如果要提交则需要做空提交(git commit --allow-empty),说明这次cherry-pick的内容可能已经在这个分支上提交过了。

可以验证:1、查看这个哈希值所修改的文件 2、查看某个文件的修改log 3、有相同的提交注释

相关推荐
江城开朗的豌豆6 分钟前
小程序登录不迷路:一篇文章搞定用户身份验证
前端·javascript·微信小程序
aesthetician11 分钟前
React 19.2.0: 新特性与优化深度解析
前端·javascript·react.js
FIN666825 分钟前
射频技术领域的领航者,昂瑞微IPO即将上会审议
前端·人工智能·前端框架·信息与通信
U.2 SSD35 分钟前
ECharts漏斗图示例
前端·javascript·echarts
江城开朗的豌豆35 分钟前
我的小程序登录优化记:从短信验证到“一键获取”手机号
前端·javascript·微信小程序
excel38 分钟前
Vue Mixin 全解析:概念、使用与源码
前端·javascript·vue.js
IT_陈寒1 小时前
Java性能优化:这5个Spring Boot隐藏技巧让你的应用提速40%
前端·人工智能·后端
勇往直前plus1 小时前
CentOS 7 环境下 RabbitMQ 的部署与 Web 管理界面基本使用指南
前端·docker·centos·rabbitmq
北海-cherish7 小时前
vue中的 watchEffect、watchAsyncEffect、watchPostEffect的区别
前端·javascript·vue.js
2501_915909068 小时前
HTML5 与 HTTPS,页面能力、必要性、常见问题与实战排查
前端·ios·小程序·https·uni-app·iphone·html5