基于 Git Submodule 的代码同步融合方案

1、背景

公司一个业务是基于A项目和B项目的代码融合发布的新版本。其中A项目为主项目,B项目为子项目,现有代码同步方案:

在A项目中运行代码同步脚本(copy.js),需要将脚本中的默认源路径替换成B目录地址,B项目需要切换到需要的分支进行同步。

js 复制代码
const defaultSourceBasePath = 'D:\Project\B项目';

弊端:

  1. 代码同步依赖两个项目切换分支
  2. 修改bug需要两个仓库单独分别提交

整体如下图所示:

如何在一个项目中完成上述操作,可以使用git submodule解决。

2、submodule实践

2.1 什么是submodule

Git Submodule是什么?

Git Submodule 是 Git 内置的一个功能,它允许在一个 "主仓库"(Parent Repository)中嵌入另一个独立的 "子仓库"(Submodule Repository)。子仓库可以是本地仓库,也可以是远程仓库(如 GitHub、GitLab 上的仓库)。

2.2 如何嵌入项目

我们A为主项目,B为子项目。

  1. 添加子项目 git submodule add <子仓库URL> <本地路径>

    1. git submodule add ssh://git@192.168.0.39:3022/A.git 在A项目下B的目录
  2. 克隆项目 git clone --recurse-submodules ssh://git@192.168.0.39:3022/e-commerce/A.git

    1. 注意:不加 --recurse-submodules克隆直接拉取,子项目文件夹会为空需要单独执行命令拉取子项目
  3. 提交代码

    1. 主项目修改提交不影响子项目
    2. 子项目修改提交后,主项目需要额外提交一次commit记录子项目的提交行为

vscode可以直接提交和切换分支:

A项目可以直接提交B项目仓库代码,父仓库只记录子仓库提交的行为。

  1. 拉取代码
    1. 注意拉取代码也是需要主项目重新提交commit,记录变化

    2. 主项目git pull 是不会拉取子项目代码,子项目拉取:

      a. 直接进入子项目文件夹git pull

      b. 主项目下直接执行git submodule foreach git pull

3、总结

最后总结一下,在A项目下使用submodule引用B项目的仓库,同步代码直接使用脚本。

优势是:

  • 无需每个人根据自己目录修改地址
  • 可以随时切换分支进行同步

如有错误,请指正O^O!

相关推荐
kyriewen1140 分钟前
异步编程:从“回调地狱”到“async/await”的救赎之路
开发语言·前端·javascript·chrome·typescript·ecmascript·html5
Old Uncle Tom42 分钟前
Markdown Viewer 再升级
前端
Luna-player44 分钟前
Vue3中使用vue-awesome-swiper
前端·vue.js·arcgis
SuperEugene1 小时前
Vue3 Pinia 状态管理规范:状态拆分、Actions 写法、持久化实战,避坑状态污染|状态管理与路由规范篇
前端·javascript·vue.js·前端框架·pinia
black方块cxy1 小时前
实现一个输入框多个ip以逗号分隔最多20组,且ip不能重复
java·服务器·前端
@PHARAOH1 小时前
WHAT - AI 时代下的候选人
大数据·前端·人工智能
竹林8182 小时前
从零到一:我在Solana NFT铸造前端中搞定@solana/web3.js连接与交易
前端·javascript
猪八宅百炼成仙2 小时前
不用点击也能预览图片:Element UI ImageViewer 命令式调用方案
前端
尘世中一位迷途小书童2 小时前
前端工程化基石:package.json 40+ 字段逐一拆解
前端·javascript·架构
OpenTiny社区2 小时前
WebMCP + WebSkills:企业级智能化页面操控方案,兼顾隐私安全与高效落地!
前端·ai编程·mcp