用git管理多项目引用的大项目最好的方式是什么呢?

我们有一些大项目,以前一直用的TFS管理,现在需要转移到git来使用。
但是转移的过程中遇到一些问题。
比如,在TFS里面,我们有一个核心项目,其他很多项目都会引用这个核心项目。在GIT里面,每个项目就是一个repo,所以repo之间如何互相引用呢?
我画了一个示意图:
引用示意图

我试过submodule和subtree,他们都会在主项目的repo下拷贝一份引用的项目的代码,这样代码就会有很多份。GIT有没有一种方式能像TFS一样,无论多少个项目互相引用,都只有一份代码,而且很好维护?

目前我们的项目结构大概是这样的:
图片描述

如果用GIT,那么product_core的代码就会被拷贝很多份。有没有会自动引用项目且不会拷贝多份代码的解决方案呢?

阅读 6.9k
4 个回答

我的理解是你们各个模块耦合在了一起。但是有些时候也是无法避免的。

公共组件或代码尽量少改动。模块化,不建议把多个项目缩成一个项目

来管理。现在很多语言都会有自己的第三方组件,这些插件也是单独用git

管理的,发行一个稳定版,日后组件有更新了再去项目中进行更新。

我理解下来,你的core相当于基础项目,这个引用关系为什么要放在源代码层面来维护呢?项目源码本来就应该是相对独立的,这样耦合在一起的目的是什么呢?
maven不是正是用来做这个工作的吗?为什么一定要在源码层引用?

拆分成独立的应用,你这种结构多分支开发很快会蛋碎一地

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进