1. 问题背景
我们原先有一个项目叫open-api,后来想要做租户独立发展,每个租户独立成一个项目,比如租户akc独立部署一个akc-open-api,租户yhd独立部署一个yhd-open-api,其中大部分代码是相同的,少量租户定制代码。所以现在想做到的是:
- 从open-api创建新的工程,如akc-open-api
- 跨工程代码合并,公共的代码修改在open-api完成,合并进akc-open-api、yhd-open-api
2. 创建项目
这一节的目的是从open-api复制一个新项目称为akc-open-api,操作步骤如下
- 克隆一个open-api项目
- 切换到想要的分支
- 移除老的git仓库
- 添加新的git仓库
- 推送到新git仓库
1. 克隆一个open-api项目
git clone git@git.abc.com:partner/open-api-web.git
2. 切换到想要的分支
checkout远程的origin/dev_tenant,创建为本地分支dev_tenant
git checkout -b dev_tenant origin/dev_tenant
3. 移除老的git仓库
先查看现在关联的git仓库
git remote -v
移除现有仓库
git remote remove origin
通过git remote -v
查看,现在已经没有关联的远程仓库了。
4. 添加新的git仓库
git remote add origin git@git.abc.com:tenant/akc-open-api-web.git
5. 推送到新git仓库
git push -u origin --all
git push -u origin --tags
2. 跨项目代码merge
上面我们从open-api项目复制了一个新的akc-open-api项目,公共的代码修我们不想重复劳动,通过修改open-api,再通过跨项目合并到不同的租户下。操作步骤如下:
1. 进入子工程目录,akc-open-api
randa@Randy MINGW64 /d/KeyniuWorkspace
$ cd akc-open-api-app/
2. 将父工程仓库关联到子工程,open-api
查看现在关联的仓库
$ 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的仓库
$ git remote add parentProject git@git.abc.com:be/open-api-app.git
再次查看,确认关联成功
$ 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, 这时候要用这个仓库名更新分支
$ git fetch parentProject
...
From git.abc.com:be/open-api-app* [new branch] dev_tenant -> parentProject/dev_tenant
4. 合并分支
现在就可以和普通的分支合并一样处理了,在idea里选git -> merge, 选中你要合并的远程分支就可以了