4

这不是重复的,因为尽管错误相同,但我的用例与其他用例不同。

我正在编译一个 go 应用程序以在 docker 上部署:

  • 最新的arch linux
  • 最新的 docker 版本,golang:alpine 镜像
  • 尝试使用 go 版本 1.13.3 和 1.14.4 linux amd64
  • 我没有 bash 脚本或错误的文件结尾。整个项目都写在这台 Linux 机器上
  • 我可以部署一个只有 fmt 打印且没有任何错误的空 go 应用程序

然而,

当我在我的 OSX 机器上构建它并将其发送到 linux 时,我可以将该可执行文件部署到 docker 而不会出现任何错误

  • OSX 莫哈韦
  • 最新的码头工人
  • 去 1.13.3
  • GOOS=Linux

错误 :

standard_init_linux.go:211: exec user process caused "no such file or directory"

4

1 回答 1

10

当你编译你的 go 应用时cgo,编译器会动态链接到libstdc.

但是,golang:alpine图像是如此之小,因为它不是使用libstdc它的简化版本,而是称为musl libc.

错误消息说

standard_init_linux.go:211: exec user process caused "no such file or directory"

如果你连接到你的形象

$ docker run -it [image] /bin/sh

假设您可以找到您的可执行文件/dist/myexec,但是当您尝试运行该可执行文件时,它会说err not found,因为它显然找不到您的可执行文件,但它找不到文件libc

解决方案是

  • 禁用 CGO:CGO_ENABLED=0在构建时使用

  • 或添加

    RUN apk add --no-cache libc6-compat
    

    给你的Dockerfile

  • 或不使用golang:alpine

要拥有一个全静态二进制可执行文件,请使用以下命令构建它:

$ CGO_ENABLED=0 GOOS=linux go build -a -ldflags '-extldflags "-static"' .
于 2020-06-29T08:14:53.233 回答