避免为本地模块的递归依赖编写 "replace"

Avoid writing "replace" for recursive dependency for local modules

我正在尝试从 GOPATH 切换到 Go Module。我有许多可执行文件使用的许多本地模块,出于安全原因我不能将它们放到网上。

当模块“d”依赖三个包:“a”、“b”、“c”时,我需要在go.mod中“替换”:

replace m.y/a => /my/a
replace m.y/b => /my/b
replace m.y/c => /my/c

当可执行文件导入包“d”时,它不会直接导入a/b/c,但它仍然需要go.mod中的“替换a,b,c”:

replace m.y/a => /my/a
replace m.y/b => /my/b
replace m.y/c => /my/c

replace m.y/d => /my/d

是设计使然还是我用错了?由于 a/b/c 已经在 d 的 go.mod 中,为什么我必须为每个使用 d 的可执行文件重新编写它们?

go 模块是否支持从另一个 go.mod 导入?还是可以不一遍又一遍地写“replace a/b/c”?

replace 不应用于修复您的源代码。它用于修复您的构建配置,通常是临时的或仅用于开发环境。

如果您的包的导入字符串已永久更改,您需要更新导入它们的源代码。这是您要避免重命名包或模块的原因之一。

这是设计使然。每 https://golang.org/ref/mod#go-mod-file-replace:

replace directives only apply in the main module's go.mod file and are ignored in other modules. See Minimal version selection for details.

如果您有一组紧耦合的包,甚至不能在本地或私人服务器上发布,那么它们应该是单个模块的一部分 (module m.y),而不是拆分成单独的模块一个(module m.y/amodule m.y/b 等)。

另一方面,如果您可以将它们发布在私人服务器上,那么您可以使用.netrc文件向go 命令,以及 GOPRIVATE 环境变量指示它不要在 public 校验和数据库中查找校验和。有关详细信息,请参阅 https://golang.org/ref/mod#private-modules