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

时间:2019-12-15 06:44:19

标签: linux ubuntu gcc alpine

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

$ /bin/bash ./hello
$ ./hello: ./hello: cannot execute binary file

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

更新 我犯了尝试将C程序作为bash脚本运行的错误。但是,更正错误后,仍然出现错误...

$ ./hello
$ bash: ./hello: No such file or directory

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

更新 让我澄清几点。

  • 在ubuntu容器中构建了一个可执行文件,并将其复制到ubuntu主机上。此可执行文件有效。
  • 另一个可执行文件是使用高山容器构建的,并已复制到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
  • 在使用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)
  • 当我在使用高山容器编译的可执行文件上运行文件时,我得到以下输出。
hello: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib/ld-, with debug_info, not stripped
  • 当我在使用高山容器编译的可执行文件上运行 ldd 时,我得到以下输出。
linux-vdso.so.1 (0x00007ffec27f7000)
libc.musl-x86_64.so.1 => not found

1 个答案:

答案 0 :(得分:1)

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

Ubuntu(和所有其他Linux中的99%)发行版使用glibc作为其标准C库实现。

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

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