Given a binary, compiled with Go using GOOS=linux
and GOARCH=amd64
, deployed to a docker
container based on alpine:3.3
, the binary will not run如果 docker 引擎主机是 Ubuntu (15.10):
sh: /bin/artisan: not found
如果 docker 引擎主机是 busybox
(这是 alpine
的基础)部署在 Mac 上的 VirtualBox VM 中,则相同的二进制文件(为相同的操作系统和架构编译)将 运行良好 操作系统 X。
如果容器基于 Ubuntu 映像之一,则同样的二进制文件也可以完美运行。
知道这个二进制文件丢失了什么吗?
这是我为重现所做的(未显示在 OS X 上的 VirtualBox/busybox 中成功运行):
构建(即使 arch 匹配,也明确地使用标志构建):
➜ artisan git:(master) ✗ GOOS=linux GOARCH=amd64 go build
检查它是否可以在主机上运行:
➜ artisan git:(master) ✗ ./artisan
10:14:04.925 [ERROR] artisan: need a command, one of server, provision or build
复制到 docker 目录,构建,运行:
➜ artisan git:(master) ✗ cp artisan docker/build/bin/
➜ artisan git:(master) ✗ cd docker
➜ docker git:(master) ✗ cat Dockerfile
FROM docker:1.10
COPY build/ /
➜ docker git:(master) ✗ docker build -t artisan .
Sending build context to Docker daemon 10.15 MB
Step 1 : FROM docker:1.10
...
➜ docker git:(master) ✗ docker run -it artisan sh
/ # /bin/artisan
sh: /bin/artisan: not found
现在将图像库更改为 phusion/baseimage
:
➜ docker git:(master) ✗ cat Dockerfile
#FROM docker:1.10
FROM phusion/baseimage
COPY build/ /
➜ docker git:(master) ✗ docker build -t artisan .
Sending build context to Docker daemon 10.15 MB
Step 1 : FROM phusion/baseimage
...
➜ docker git:(master) ✗ docker run -it artisan sh
# /bin/artisan
08:16:39.424 [ERROR] artisan: need a command, one of server, provision or build
原文由 Oleg Sklyar 发布,翻译遵循 CC BY-SA 4.0 许可协议
默认情况下,如果使用
net
包,构建可能会生成带有一些动态链接的二进制文件,例如到 libc。您可以通过查看ldd output.bin
的结果来检查动态链接与静态链接我遇到过两种解决方案:
CGO_ENABLED=0
go build -tags netgo -a -v
,这是针对特定平台实现的来自 https://golang.org/doc/go1.2 :
以上假定唯一的 CGO 依赖项是标准库的
net
包。