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

浏览:21日期:2023-10-08

问题描述

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

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

目前我们的项目结构大概是这样的:tfs - 用git管理多项目引用的大项目最好的方式是什么呢?

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

问题解答

回答1:

如果是java工程的话,推荐用Maven或者gradle管理项目依赖,再用git管理项目工程。当然Maven,gradle也能管理非java工程。

搜索了一番,这个问题与题主类似:http://programmers.stackexchange.com/questions/114719/organizing-git-repositories-with-common-nested-sub-modules

回答2:

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

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

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

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

回答3:

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

回答4:

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

相关文章: