登录
首页 >  Golang >  Go问答

建立一个由多个Go模块构成的Golang项目:包括一个“核心”模块和多个引用“核心”模块的“适配器”模块

来源:stackoverflow

时间:2024-02-16 16:27:22 457浏览 收藏

一分耕耘,一分收获!既然打开了这篇文章《建立一个由多个Go模块构成的Golang项目:包括一个“核心”模块和多个引用“核心”模块的“适配器”模块》,就坚持看下去吧!文中内容包含等等知识点...希望你能在阅读本文后,能真真实实学到知识或者帮你解决心中的疑惑,也欢迎大佬或者新人朋友们多留言评论,多给建议!谢谢!

问题内容

很难用一句话来表达,但情况就是这样。我正在开发一个 golang 包,我的目的是让它成为 go-gettable。该包的核心提供了一些“核心”功能,即 http 中间件。我需要几个“适配器”包来支持一些最著名的 golang http 框架。

每个适配器的职责是从http请求中获取所需的信息,然后使用逻辑所在的核心服务。因此,主要逻辑驻留在一个位置,而每个适配器的行为就像一个适配器。

我能想到的第一种方法是将核心和适配器作为同一模块的一部分,但这会给导入项目添加很多不必要的依赖项。例如,如果您想导入包以支持框架 a,则包将间接添加其他框架的适配器所需的所有依赖项,即使未使用也是如此。

我正在考虑的方法是在同一个包中包含多个模块:一个核心模块和每个适配器的单独模块。然后每个适配器模块将导入核心模块:

|- core
|  |- go.mod
|
|- adapter1
|  |- go.mod
|
|- adapter2
   |- go.mod

这样,适配器 1 模块就可以被导入,并且只携带它的依赖项和核心模块的依赖项,而适配器 2 的依赖项则不包含在内。

我让这个结构在本地工作:我可以使用 go mod replace 语句从另一个 golang 项目成功导入适配器 1 或适配器 2,但是当我将更改推送到 git 存储库并尝试直接从那里导入时,我可以' t get go mod 下载每个包的最新版本/标签,甚至不需要明确提供我想要使用的版本标签。它不断下载旧版本并抱怨缺少一些代码部分(仅存在于最新版本中)。

我遵循本指南在单个存储库上获取多个模块,但一个重要的区别是,就我而言,我正在获取引用同一存储库中另一个模块的模块,而指南中的示例显示了如何获取模块独立。

所以我的问题是,是否有可能获取一个引用同一存储库上另一个 go 模块的 go 模块?

将我的“核心”模块放在单独的存储库上,然后将“适配器”存储库/模块(每个适配器都有一个包)放在一起,这会是更好的方法吗?

将所有内容都放在同一个存储库中的目的是使开发更容易,但它使版本控制变得非常复杂。

任何建议将不胜感激。如果您需要我澄清一些事情,我很乐意这样做。提前致谢。


正确答案


请考虑一下,在 go.mod (issue 44840) 中使用 replace directive 不可能进行任何 go 安装。

这会导致错误消息:

The go.mod file for the module providing named packages contains one or more 
replace directives. 

It must not contain directives that would cause it to be interpreted differently 
than if it were the main module.

因此,每个存储库一个模块是更好的选择,然后为了方便起见,您可以将存储库分组到一个父 git 存储库(通过 submodules,每个 following a branch 以便于更新)。

好了,本文到此结束,带大家了解了《建立一个由多个Go模块构成的Golang项目:包括一个“核心”模块和多个引用“核心”模块的“适配器”模块》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>