当前位置: 首页 > 面试题库 >

Go编译的二进制文件不会在Ubuntu主机上的高山Docker容器中运行

仲阳朔
2023-03-14
问题内容

给定一个二进制文件,使用Go使用GOOS=linuxand
编译该二进制文件,并将其GOARCH=amd64部署到docker基于的容器中alpine:3.3,如果Docker引擎主机为Ubuntu(15.10),则该二进制文件将不会运行:

sh: /bin/artisan: not found

如果将docker引擎主机(作为的基础)部署在Mac OS X上的VirtualBox VM中,则该相同的二进制文件(针对相同的OS和Arch编译)将
运行良好busybox``alpine

如果容器基于Ubuntu映像之一,则同样的二进制文件也可以很好地运行。

知道这个二进制文件缺少什么吗?

这是我要做的复制操作(未显示在OS X的VirtualBox / busybox中成功运行):

构建(即使拱门匹配,也将使用标志显式构建):

➜  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 dir,构建并运行:

➜  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

问题答案:

默认情况下,如果使用该net软件包,则内部版本可能会生成带有某些动态链接(例如到libc)的二进制文件。您可以通过查看以下结果来动态检查静态链接ldd output.bin

我遇到了两种解决方案:

  • 通过禁用CGO CGO_ENABLED=0
  • 强制使用net依赖项netgo的Go实现go build -tags netgo -a -v,这是在某些平台上实现的

从https://golang.org/doc/go1.2:

默认情况下,net软件包需要cgo,因为主机操作系统通常必须进行中介网络调用设置。但是,在某些系统上,可以使用不带cgo的网络,这样做很有用,例如,避免动态链接。新的构建标签netgo(默认情况下为off)允许在可能的系统上以纯Go格式构建net软件包。

上面假设唯一的CGO依赖项是标准库的net程序包。



 类似资料:
  • 给定一个二进制文件,使用和用Go编译,部署到基于的容器中,如果docker引擎主机是Ubuntu(15.10): 如果docker引擎主机是部署在Mac OS X上的VirtualBox VM中的(这是)的基础,则相同的二进制文件(为相同的OS和arch编译)将运行良好。 如果容器基于一个Ubuntu图像,这个二进制文件也可以运行得很好。 知道这个二进制缺少什么吗? 复制到docker目录,生成,

  • 问题内容: 我正在尝试编写一个使用alpine并利用预编译golang的dockerfile。 我正在/ bin / sh /:./go:找不到 它可以在我的ubuntu笔记本电脑上正常工作,所以我不确定这有什么区别。我做了一个快速的谷歌,我找不到任何明显的东西,指出缺少的东西。 问题答案: Alpine是使用MUSL C库构建的。您不能在这种环境下运行为glibc编译的二进制文件。您将需要找到为

  • 问题内容: 感谢您收看这个问题。 所以我的问题与如何在docker-compose up指令上运行脚本的最佳实践有关。 目前,我正在主机和容器之间共享一个卷,以使脚本更改对主机和容器均可见。与监视脚本轮询配置文件中的更改类似。 该脚本必须根据预定义规则对主机进行更改。 所以我的问题是: 我如何才能在docker-compose up指令上甚至从服务的dockerfile上启动此脚本,以便每当容器启

  • 我正在考虑使用Docker在持续集成(CI)服务器上构建我的依赖项,这样我就不必在代理本身上安装所有的运行时和库。 为了实现这一点,我需要将在容器中构建的构建构件复制回主机中。有可能吗?

  • 问题内容: Docker对我来说在Mac上运行良好,但是我必须在VirtualBox(或Parallels或VMWare Fusion)中运行docker主机,因为Mac的内核不支持docker。 所以我尝试在Ubuntu桌面上设置应用程序和docker-compose- 本机地,其中docker客户端和docker主机都物理上运行在同一系统上。这可行,但是我正在运行的Docker容器无法写入已安

  • 问题内容: Docker容器中有多个进程正在运行,它们的PID在容器名称空间中是隔离的,是否有办法找出Docker主机上的PID是什么? 例如,有一个Apache Web服务器在Docker容器中运行(我使用Docker Hub中的 Apache + PHP映像),而Apache在启动时会在容器内创建更多工作进程。这些工作进程实际上正在处理传入的请求。要查看这些进程,我在docker容器中运行: