无法使用 Docker 构建包含内部包的 Golang 项目。

huangapple go评论90阅读模式
英文:

Can't docker build a Golang project with internal packages

问题

我正在尝试构建一个包含不同级别包的 Golang 项目。我在这里上传了一个示例项目:https://github.com/David-Lor/archive.org-telegrambot/tree/example-go-dockerfile-not-building

文件

go.mod

module github.com/David-Lor/go-example

go 1.16

require github.com/gammazero/workerpool v1.1.2

Dockerfile

FROM golang:1.17.7

WORKDIR /app
COPY ./src/go.mod .
COPY ./src/go.sum .
RUN go mod download


COPY ./src/* ./
#RUN ls -lah # 文件已正确复制;go.mod 和 main.go 在当前目录中
RUN go build -o /tmp/built

错误

当我执行 docker build 时,在 go build 命令上出现以下错误:

Step 7/7 : RUN go build -o /tmp/built
 ---> Running in 72358fb165c4
main.go:8:2: no required module provides package github.com/David-Lor/go-example/internal/foo; to add it:
        go get github.com/David-Lor/go-example/internal/foo
main.go:9:2: no required module provides package github.com/David-Lor/go-example/internal/foo/bar; to add it:
        go get github.com/David-Lor/go-example/internal/foo/bar
The command '/bin/sh -c go build -o /tmp/built' returned a non-zero code: 1

然而,如果我运行基础的 Docker 镜像并从那里构建或运行应用程序,在主机系统上也可以正常工作:

$ sudo docker run -it --rm -v $(pwd):/data golang:1.17.7
root@e468a186536f:/go# cd /data/src
root@e468a186536f:/data/src# go build -o /tmp/built
go: downloading github.com/gammazero/workerpool v1.1.2
go: downloading github.com/gammazero/deque v0.1.0
root@e468a186536f:/data/src# /tmp/built
internal/foo
internal/foo/bar
root@e468a186536f:/data/src# go run main.go
internal/foo
internal/foo/bar
英文:

I'm trying to build a Golang project, which contains different levels of packages inside. I've uploaded an example project here: https://github.com/David-Lor/archive.org-telegrambot/tree/example-go-dockerfile-not-building

Files

go.mod

module github.com/David-Lor/go-example

go 1.16

require github.com/gammazero/workerpool v1.1.2

Dockerfile

FROM golang:1.17.7

WORKDIR /app
COPY ./src/go.mod .
COPY ./src/go.sum .
RUN go mod download


COPY ./src/* ./
#RUN ls -lah # files are copied correctly; go.mod and main.go are in current directory
RUN go build -o /tmp/built

Error

When I docker build, I got the following error on the go build command:

Step 7/7 : RUN go build -o /tmp/built
 ---> Running in 72358fb165c4
main.go:8:2: no required module provides package github.com/David-Lor/go-example/internal/foo; to add it:
        go get github.com/David-Lor/go-example/internal/foo
main.go:9:2: no required module provides package github.com/David-Lor/go-example/internal/foo/bar; to add it:
        go get github.com/David-Lor/go-example/internal/foo/bar
The command '/bin/sh -c go build -o /tmp/built' returned a non-zero code: 1

However, if I run the base docker image and go build or go run the app from there, it works fine (from the host system runs fine too):

$ sudo docker run -it --rm -v $(pwd):/data golang:1.17.7
root@e468a186536f:/go# cd /data/src
root@e468a186536f:/data/src# go build -o /tmp/built
go: downloading github.com/gammazero/workerpool v1.1.2
go: downloading github.com/gammazero/deque v0.1.0
root@e468a186536f:/data/src# /tmp/built
internal/foo
internal/foo/bar
root@e468a186536f:/data/src# go run main.go
internal/foo
internal/foo/bar

答案1

得分: 3

问题出在你的 Dockerfile 中,在执行 COPY ./src/* ./ 操作之后,你的镜像中的目录结构如下所示:

ZZ> docker run -it d1fae37bbfb1 /bin/sh
# cd /app
# ls -al
total 2048
drwxr-xr-x 1 root root    4096 Feb 16 19:58 .
drwxr-xr-x 1 root root    4096 Feb 16 19:59 ..
drwxr-xr-x 3 root root    4096 Feb 16 19:52 foo
-rwxr-xr-x 1 root root      97 Feb 16 19:57 go.mod
-rwxr-xr-x 1 root root     352 Feb 16 19:52 go.sum
-rwxr-xr-x 1 root root     295 Feb 16 19:52 main.go
# ls foo
bar  foo.go

所以没有 internal 文件夹,这就是构建失败的原因。

如果你将这行代码改为 COPY src ./,构建将成功完成。

英文:

The issue is in your Dockerfile; after the operation COPY ./src/* ./ the directory structure in your image is as follows:

ZZ> docker run -it d1fae37bbfb1 /bin/sh
# cd /app
# ls -al
total 2048
drwxr-xr-x 1 root root    4096 Feb 16 19:58 .
drwxr-xr-x 1 root root    4096 Feb 16 19:59 ..
drwxr-xr-x 3 root root    4096 Feb 16 19:52 foo
-rwxr-xr-x 1 root root      97 Feb 16 19:57 go.mod
-rwxr-xr-x 1 root root     352 Feb 16 19:52 go.sum
-rwxr-xr-x 1 root root     295 Feb 16 19:52 main.go
# ls foo
bar  foo.go

So there is no internal folder which is why the build is failing.

The build will complete successfully if you change this line to:

COPY src ./

huangapple
  • 本文由 发表于 2022年2月17日 03:44:52
  • 转载请务必保留本文链接:https://go.coder-hub.com/71148343.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定