Git 仓库间代码迁移 | merge cherry-pick

2024-09-03 22:20

本文主要是介绍Git 仓库间代码迁移 | merge cherry-pick,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

工作中遇到了这样场景:原工程 A 由于业务发展,衍生出了 B 工程,至此两个工程独立迭代。A 工程近期上线了一个功能,B 工程也希望具备该功能,需要研发同学做代码的同步。

问题简化:如何在两个 git 仓库间做代码迁移。


回溯一下,如果将代码从一个分支迁移到另一个分支。

  • 如果需要所有代码变动,可以使用 merge 操作;
  • 如果需要部分代码变动(某几个提交),可以使用 cherry-pick 操作。

merge

将两个或多个分支的历史合并在一起。

$ git merge --helpNAMEgit-merge - Join two or more development histories together
...

示例:

🐫 将 branchA branchB 合并到当前分支

$ git merge branchA branchB

🐎 将 branchA 合并到当前分支,使用 ours 的合并策略:

$ git merge -s ours branchA

三种常见的合并策略:ourstheirsrecursive

选择合适的合并策略取决于具体需求和合并的场景

选项说明
recursive(默认)尝试找到两个分支的共同祖先,然后分别将两个分支的改动应用到共同祖先上,最后将这些改动合并到一起
ours优先选择主分支(通常是当前所在的分支)的改动
theirs优先选择要合并进来的分支的改动

仓库间合并

# 追加源
$ git remote add originNew git://url
# 将新追加源远程内容获取本地
$ git fetch originNew
# merge
$ git merge branchName

当然也可以直接合并远程

# 追加源
$ git remote add originNew git://url
# merge
$ git merge originNew/branchName

git fetch 从另一个存储库下载objects和refs

# 从多个获取
$ git fetch origin originNew
# 获取全部
$ git fetch --all

cherry-pick

允许开发者精确地选择和应用特定的提交到不同的分支。

$ git cherry-pick --helpNAMEgit-cherry-pick - Apply the changes introduced by some existing commits

允许将一个或多个已有的提交从一个分支应用到当前分支。这就像是从另一个分支“挑选”提交并将其“复制”到当前的工作分支。

示例

🐫 某个特定的提交:commit-hash 应用到当前分支

$ git cherry-pick <commit-hash>

🐎 一系列提交:commit1commit2 的所有提交应用到当前分支

$ git cherry-pick commit1..commit2

🐏 某合并的提交:mergeCommit 应用到当前分支

$ git cherry-pick -m 1 <mergeCommit>

针对 merge 的 cherry-pick,不知道合并的哪一边应该被视为主线。通过 -m 指定,1 代表父分支。

🐕 只想将变更应用到工作目录和索引,而不创建新的提交

$ git cherry-pick -n <commit-hash>

🐃 将指定提交中对特定文件的变更应用到工作目录和索引

$ git rev-list --reverse <commit-hash> -- <file-path> | git cherry-pick -n --stdin

避免冲突

在 cherry-pick 过程中可能会遇到冲突,Git 会暂停操作并让需要手动解决。解决冲突后,需要继续操作:

$ git cherry-pick --continue

如果决定放弃 cherry-pick,可以使用:

$ git cherry-pick --abort

仓库间应用

# 追加源
$ git remote add originNew git://url
# 将新追加源远程内容获取本地
$ git fetch originNew
# cherry-pick
$ git cherry-pick commit1..commit2

这篇关于Git 仓库间代码迁移 | merge cherry-pick的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1134208

相关文章

MySQL 迁移至 Doris 最佳实践方案(最新整理)

《MySQL迁移至Doris最佳实践方案(最新整理)》本文将深入剖析三种经过实践验证的MySQL迁移至Doris的最佳方案,涵盖全量迁移、增量同步、混合迁移以及基于CDC(ChangeData... 目录一、China编程JDBC Catalog 联邦查询方案(适合跨库实时查询)1. 方案概述2. 环境要求3.

IDEA中新建/切换Git分支的实现步骤

《IDEA中新建/切换Git分支的实现步骤》本文主要介绍了IDEA中新建/切换Git分支的实现步骤,通过菜单创建新分支并选择是否切换,创建后在Git详情或右键Checkout中切换分支,感兴趣的可以了... 前提:项目已被Git托管1、点击上方栏Git->NewBrancjsh...2、输入新的分支的

java实现docker镜像上传到harbor仓库的方式

《java实现docker镜像上传到harbor仓库的方式》:本文主要介绍java实现docker镜像上传到harbor仓库的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 前 言2. 编写工具类2.1 引入依赖包2.2 使用当前服务器的docker环境推送镜像2.2

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

Java实现自定义table宽高的示例代码

《Java实现自定义table宽高的示例代码》在桌面应用、管理系统乃至报表工具中,表格(JTable)作为最常用的数据展示组件,不仅承载对数据的增删改查,还需要配合布局与视觉需求,而JavaSwing... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

Go语言代码格式化的技巧分享

《Go语言代码格式化的技巧分享》在Go语言的开发过程中,代码格式化是一个看似细微却至关重要的环节,良好的代码格式化不仅能提升代码的可读性,还能促进团队协作,减少因代码风格差异引发的问题,Go在代码格式... 目录一、Go 语言代码格式化的重要性二、Go 语言代码格式化工具:gofmt 与 go fmt(一)

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.