小编典典

单个主机上的多个 glibc 库

all

我的 linux (SLES-8) 服务器目前有 glibc-2.2.5-235,但我有一个程序不能在这个版本上运行,需要 glibc-2.3.3。

是否可以在同一主机上安装多个 glibcs​​?

这是我在旧 glibc 上运行程序时遇到的错误:

./myapp: /lib/i686/libc.so.6: version `GLIBC_2.3' not found (required by ./myapp)
./myapp: /lib/i686/libpthread.so.0: version `GLIBC_2.3.2' not found (required by ./myapp)
./myapp: /lib/i686/libc.so.6: version `GLIBC_2.3' not found (required by ./libxerces-c.so.27)
./myapp: /lib/ld-linux.so.2: version `GLIBC_2.3' not found (required by ./libstdc++.so.6)
./myapp: /lib/i686/libc.so.6: version `GLIBC_2.3' not found (required by ./libstdc++.so.6)

所以我创建了一个名为 newglibc 的新目录并将以下文件复制到:

libpthread.so.0
libm.so.6
libc.so.6
ld-2.3.3.so
ld-linux.so.2 -> ld-2.3.3.so

export LD_LIBRARY_PATH=newglibc:$LD_LIBRARY_PATH

但我收到一个错误:

./myapp: /lib/ld-linux.so.2: version `GLIBC_PRIVATE' not found (required by ./newglibc/libpthread.so.0)
./myapp: /lib/ld-linux.so.2: version `GLIBC_2.3' not found (required by libstdc++.so.6)
./myapp: /lib/ld-linux.so.2: version `GLIBC_PRIVATE' not found (required by ./newglibc/libm.so.6)
./myapp: /lib/ld-linux.so.2: version `GLIBC_2.3' not found (required by ./newglibc/libc.so.6)
./myapp: /lib/ld-linux.so.2: version `GLIBC_PRIVATE' not found (required by ./newglibc/libc.so.6)

因此,它们似乎仍在链接到我放置它们的位置,/lib而不是从我放置它们的位置获取。


阅读 65

收藏
2022-06-27

共1个答案

小编典典

在同一个系统上很可能有多个版本的 glibc(我们每天都这样做)。

但是,您需要知道 glibc 由许多必须匹配的部分(200 多个共享库)组成。其中之一是 ld-linux.so.2,它 必须 与 libc.so.6
匹配,否则您将看到您所看到的错误。

ld-linux.so.2 的绝对路径在链接时被硬编码到可执行文件中,并且在链接完成后无法轻易更改(更新:可以使用
patchelf完成;请参阅下面的答案)。

要构建可与新 glibc 一起使用的可执行文件,请执行以下操作:

g++ main.o -o myapp ... \
   -Wl,--rpath=/path/to/newglibc \
   -Wl,--dynamic-linker=/path/to/newglibc/ld-linux.so.2

-rpath链接器选项将使运行时加载程序在其中搜索库(/path/to/newglibc因此您不必LD_LIBRARY_PATH在运行它之前进行设置),并且该-dynamic- linker选项将“烘焙”路径以更正ld-linux.so.2到应用程序中。

如果您无法重新链接myapp应用程序(例如,因为它是第三方二进制文件),并非所有内容都会丢失,但它会变得更加棘手。一种解决方案是为其设置适当的chroot环境。另一种可能性是使用rtldi和二进制编辑器。更新:或者你可以使用patchelf

2022-06-27