我的 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而不是从我放置它们的位置获取。
/lib
在同一个系统上很可能有多个版本的 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到应用程序中。
-rpath
/path/to/newglibc
LD_LIBRARY_PATH
-dynamic- linker
ld-linux.so.2
如果您无法重新链接myapp应用程序(例如,因为它是第三方二进制文件),并非所有内容都会丢失,但它会变得更加棘手。一种解决方案是为其设置适当的chroot环境。另一种可能性是使用rtldi和二进制编辑器。更新:或者你可以使用patchelf。
myapp
chroot