我对 golang 和 docker 还是很陌生,所以在查看了许多线程和互联网资源之后,我最终对应该如何设置感到困惑。
我的问题是由于未找到本地依赖项,我正面临 golang 应用程序的 docker build 错误。
仅供参考(本地机器):go 版本 go1.13.4 linux/amd64
这是我的问题的背景:
我有一个存储库,它将保存将在 Kubernetes 中运行的简单微服务(用 Go 编写)的源代码。所以存储库中的每个文件夹都代表一个服务。我还有一个文件夹“工具”,它重新组合了许多服务共享的辅助功能和资源。我的存储库不在任何 Go 特殊路径中,它位于我的一个驱动器的根目录中。所以这是我的回购的样子:
.
├── service1
│ ├── main.go
│ ├── Dockerfile
│ ├── go.mod
│ └── go.sum
├── service2
├── service3
│ ...
├── serviceX
├── tools
│ ├── helpers.go
│ ├── ressources.go
│ ├── go.mod
└── └── go.sum
因此,每个文件夹/服务都是一个独立处理其依赖关系的 go 模块。文件夹工具也是一个模块。我初始化了每个模块go mod init FOLDER_NAME
在服务service1 中,我引用了模块工具来使用一些功能。这是我实现它的方式:(./service1/main.go 的 src)
package main
import (
"fmt"
st "../tools"
// other modules imports
)
func main() {
st.ExecHelperFunc()
// http server inits
}
当我在本地运行service1 的main.go 或者如果我在本地构建它并在之后运行二进制文件时,服务工作正常。
但是当我尝试构建 service1 的dockerfile时,我得到 golang build 错误:
build _/go/src/app/tools: cannot find module for path _/go/src/app/tools
这是我的码头文件:
FROM golang:1.13 as builder
ENV GO111MODULE=on
WORKDIR /go/src/app
COPY ./tools ./tools
COPY ./service1 ./service1
WORKDIR /go/src/app/tools
RUN go mod download
WORKDIR /go/src/app/service1
RUN go mod download
WORKDIR /go/src/app
RUN go build -o server /go/src/app/service1/main.go
FROM centos:7
RUN yum -y update && yum clean all
COPY --from=builder /go/src/app/server .
EXPOSE 3000
CMD ["./server"]
所以我不明白为什么docker无法构建服务?显然他无法定位/识别模块工具,但为什么呢?我为 dockerfile 尝试了许多不同的设置,但我仍然无法弄清楚。
预先感谢您的帮助。
更新:
正如答案中所建议的那样,将dockerfile中 GO111MODULE 的值从 on 更改为 auto 并不能修复构建错误,而是让我得到一个新错误:
unexpected directory layout:
import path: _/go/src/app/tools
root: /go/src
dir: /go/src/app/tools
expand root: /go
expand dir: /go/src/app/tools
separator: /