首页 >后端开发 >Golang >Go:具有共享代码的微服务的存储库布局

Go:具有共享代码的微服务的存储库布局

王林
王林转载
2024-02-09 09:33:28835浏览

Go:具有共享代码的微服务的存储库布局

Go是一种强大的编程语言,近年来在微服务架构中越来越受欢迎。它的简洁性、高效性和并发性使其成为构建高性能应用程序的理想选择。在使用Go构建微服务时,存储库的布局是一个重要的考虑因素。在本文中,php小编香蕉将介绍一种具有共享代码的微服务存储库布局,帮助您更好地组织和管理代码。

问题内容

我们最近开始使用 go 来开发新的微服务。每个微服务都是一个 go 模块,我们将它们作为单一存储库进行管理:

/
  services/
    s1/
      go.mod
      main.go
    s2/
      go.mod
      main.go

这工作正常,但现在我们需要在 s1s2 之间共享一些代码 - 两个服务使用的一些结构、上传到 s3 的函数等。

处理这种情况的正确方法是什么?理想情况下,我在存储库根目录中有一个 common 目录(services 的同级目录)并将公共代码放在那里 - 但是在编译 common 目录(services 的同级目录)并将公共代码放在那里 - 但是在编译 s1s2 时,go 将如何从那里获取代码?

解决方法

我认为你所问的实际上只是“如何构建 go 应用程序以生成多个二进制文件?”。

您可以将 go.mod 移动到顶级目录重命名,以便您拥有以下布局:

.
├── common
│   └── common.go
├── go.mod
└── services
    ├── s1
    │   └── main.go
    └── s2
        └── main.go

还有一个 go.mod ,其开头类似:

module mymodule

如果 common/common.go 看起来像这样:

package common

func commonfunction() string {
    return "this is a common function"
}

然后在services/s1/main.go中,可以导入common模块:

package main

import (
        "mymodule/common"
        "fmt"
)

func main() {
        res := common.commonfunction()
        fmt.println(res)
}

您将像这样构建 s1 服务:

go build ./services/s1

构建 s2 类似:

go build ./services/s2

您通常会有一个顶级 makefile 来自动构建多个服务。

以上是Go:具有共享代码的微服务的存储库布局的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文转载于:stackoverflow.com。如有侵权,请联系admin@php.cn删除