为什么我不能在 ubuntu 上运行基于 alpine 的 C 程序?

Tyl*_*r K 2 linux ubuntu gcc alpine-linux

我在 alpine linux 容器内编译了一个简单的 hello world C 程序,并将其复制到我的 ubuntu 主机上。令我惊讶的是,我无法在我的 ubuntu 主机上运行二进制文件。相反,当我尝试执行程序时出现以下错误。

$ /bin/bash ./hello
$ ./hello: ./hello: cannot execute binary file
Run Code Online (Sandbox Code Playgroud)

为什么我不能在 ubuntu 上运行我在 alpine 上编译的程序?

更新 我犯了一个错误,试图将 C 程序作为 bash 脚本运行。然而,在纠正我的错误后,我仍然得到一个错误......

$ ./hello
$ bash: ./hello: No such file or directory
Run Code Online (Sandbox Code Playgroud)

我已经使二进制可执行文件,所以这不应该是问题。运行在主机上编译的相同程序时不会显示此错误消息。

更新 让我澄清几点。

  • 一个可执行文件构建在 ubuntu 容器中并复制到 ubuntu 主机上。这个可执行文件有效。
  • 另一个可执行文件是使用 alpine 容器构建的,并复制到 ubuntu 主机上。此可执行文件不起作用。
  • 两个可执行文件都设置了它们的可执行位。当我运行 ./hello 时,我会在相关可执行文件所在的目录中执行此操作。
  • 当我在使用 ubuntu 容器编译的可执行文件上运行文件时,我得到以下输出。
hello: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/l, for GNU/Linux 3.2.0, BuildID[sha1]=bc9e3e2ecfc026f8077dca28dbbdee4778862d7a, not stripped
Run Code Online (Sandbox Code Playgroud)
  • 当我在使用 ubuntu 容器编译的可执行文件上运行ldd 时,我得到以下输出。
linux-vdso.so.1 (0x00007ffdbc79e000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f517b5ae000)
/lib64/ld-linux-x86-64.so.2 (0x00007f517bba1000)
Run Code Online (Sandbox Code Playgroud)
  • 当我在使用 alpine 容器编译的可执行文件上运行文件时,我得到以下输出。
hello: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib/ld-, with debug_info, not stripped
Run Code Online (Sandbox Code Playgroud)
  • 当我在使用 alpine 容器编译的可执行文件上运行ldd 时,我得到以下输出。
linux-vdso.so.1 (0x00007ffec27f7000)
libc.musl-x86_64.so.1 => not found
Run Code Online (Sandbox Code Playgroud)

Kam*_*Cuk 7

Alpine 发行版使用musl作为标准的 C 库实现。

Ubuntu(以及 99% 的所有其他 linux)发行版使用glibc作为它们的标准 C 库实现。

他们与自己格格不入。“不兼容”是指在 alpine 下编译的二进制文件与 musl 库链接,而不是与 glibc 链接。

有两种解决方案。您可以在 ubuntu 中安装 musl 库,以便二进制文件可以链接到它。您可以在 alpine 中安装 glibc 并在 alpine 中编译二进制文件,同时将其链接到 glibc。或者您可以针对 musl 静态编译二进制文件。