Git仓库拆分和Merge

1. 问题背景

我们原先有一个项目叫open-api,后来想要做租户独立发展,每个租户独立成一个项目,比如租户akc独立部署一个akc-open-api,租户yhd独立部署一个yhd-open-api,其中大部分代码是相同的,少量租户定制代码。所以现在想做到的是:

  1. 从open-api创建新的工程,如akc-open-api
  2. 跨工程代码合并,公共的代码修改在open-api完成,合并进akc-open-api、yhd-open-api

2. 创建项目

这一节的目的是从open-api复制一个新项目称为akc-open-api,操作步骤如下

  1. 克隆一个open-api项目
  2. 切换到想要的分支
  3. 移除老的git仓库
  4. 添加新的git仓库
  5. 推送到新git仓库
1. 克隆一个open-api项目
bash 复制代码
 git clone git@git.abc.com:partner/open-api-web.git
2. 切换到想要的分支

checkout远程的origin/dev_tenant,创建为本地分支dev_tenant

bash 复制代码
git checkout -b dev_tenant origin/dev_tenant
3. 移除老的git仓库

先查看现在关联的git仓库

bash 复制代码
git remote -v

移除现有仓库

bash 复制代码
git remote remove origin

通过git remote -v查看,现在已经没有关联的远程仓库了。

4. 添加新的git仓库
bash 复制代码
git remote add origin git@git.abc.com:tenant/akc-open-api-web.git
5. 推送到新git仓库
bash 复制代码
git push -u origin --all
git push -u origin --tags

2. 跨项目代码merge

上面我们从open-api项目复制了一个新的akc-open-api项目,公共的代码修我们不想重复劳动,通过修改open-api,再通过跨项目合并到不同的租户下。操作步骤如下:

1. 进入子工程目录,akc-open-api
bash 复制代码
randa@Randy MINGW64 /d/KeyniuWorkspace
$ cd akc-open-api-app/
2. 将父工程仓库关联到子工程,open-api

查看现在关联的仓库

bash 复制代码
$ git remote -v
origin  git@git.abc.com:tenant/akc-open-api-app.git (fetch)
origin  git@git.abc.com:tenant/akc-open-api-app.git (push)

关联open-api的仓库

bash 复制代码
$ git remote add parentProject git@git.abc.com:be/open-api-app.git

再次查看,确认关联成功

bash 复制代码
$ git remote -v
origin  git@git.abc.com:tenant/akc-open-api-app.git (fetch)
origin  git@git.abc.com:tenant/akc-open-api-app.git (push)
parentProject   git@git.abc.com:be/open-api-app.git (fetch)
parentProject   git@git.abc.com:be/open-api-app.git (push)
3. 更新父工程的代码

关联的时候我们把仓库名取名为parentProject, 这时候要用这个仓库名更新分支

bash 复制代码
$ git fetch parentProject
...
From git.abc.com:be/open-api-app
 * [new branch]      dev_tenant   -> parentProject/dev_tenant
4. 合并分支

现在就可以和普通的分支合并一样处理了,在idea里选git -> merge, 选中你要合并的远程分支就可以了

相关推荐
2301_7720935613 分钟前
tuchuang_myfiles&&share文件列表_共享文件
大数据·前端·javascript·数据库·redis·分布式·缓存
K_i13417 分钟前
电信大数据实战:MySQL与Hadoop高效同步
大数据·hadoop·mysql
sitellla36 分钟前
Testify Go测试工具包入门教程
git·测试工具·其他·golang
sensen_kiss44 分钟前
INT305 Machine Learning 机器学习 Pt.3二元分类和多类分类
大数据·机器学习·分类
B站计算机毕业设计之家6 小时前
智慧交通项目:Python+PySide6 车辆检测系统 YOLOv8+OpenCV 自定义视频 自定义检测区域 (源码+文档)✅
大数据·python·opencv·yolo·智慧交通·交通·车流量
数据与人工智能律师7 小时前
AI的法治迷宫:技术层、模型层、应用层的法律痛点
大数据·网络·人工智能·云计算·区块链
码上地球13 小时前
大数据成矿预测系列(三) | 从统计模型到机器学习:为何机器学习是成矿预测的新前沿?
大数据·机器学习·数据挖掘
Hello.Reader13 小时前
Flink 作业测试依赖、MiniCluster、DataStream 与 Table/SQL 上手
大数据·sql·flink
代码匠心14 小时前
从零开始学Flink:实时流处理实战
java·大数据·后端·flink
cxr82815 小时前
AI智能体赋能文化传承与创新领域:社群身份认同的数字空间重构与文化融合策略
大数据·人工智能·重构·提示词工程·ai赋能