我想构建一个 Go 1.9.2 二进制文件并在 Docker Alpine 镜像上运行它。我编写的 Go 代码不调用任何 C 代码。它还使用 net
包。不幸的是,它并不像听起来那么简单,因为 Go 似乎并没有一直构建静态二进制文件。当我尝试执行二进制文件时,我经常收到关于为什么二进制文件没有执行的神秘消息。互联网上有相当多的信息,但其中大部分最终都是人们使用试错来使他们的二进制文件工作。
到目前为止,我找到了以下作品,但是我不知道为什么,它是最佳的还是可以简化的。
env GOOS=linux GARCH=amd64 go install -v -a -tags netgo -installsuffix netgo -ldflags "-linkmode external -extldflags -static"
构建将在 Alpine 3.7 docker 镜像上运行的 Go 二进制文件的规范方法(如果存在(是什么?我很乐意使用 apk
将软件包安装到 Alpine 映像,如果这样可以使事情更有效/更容易。(相信无论如何我都需要安装ca-certificates
。
是的,您经常需要添加额外的资源文件,例如证书,尤其是在使用像alpine这样的最小发行版时,但是您可以在如此小的发行版上运行go应用程序这一事实通常也被视为一种优势。
要添加证书,这是一个很好的解释,概述了如何在暂存容器上执行此操作:
https://blog.codeship.com/building-minimal-docker-containers-for-go-applications/
如果你宁愿坚持使用高山,那么你可以安装这个软件包来获取它们:
https://pkgs.alpinelinux.org/package/v3.7/main/x86/ca-certificates