Я скомпилировал Apache httpd на CentOS 6.x. Там отлично работает.
Затем я переместил двоичные файлы в CentOS 7. Мне нужно было установить некоторые недостающие библиотеки, и теперь они отлично работают.
Затем я переместил двоичные файлы в Archlinux. Как я и ожидал, началось не сразу:
httpd: symbol lookup error: /software_pack/httpd-2.2.25/lib/libapr-1.so.0: undefined symbol: dlopen
Однако если я это сделаю ldd /software_pack/httpd-2.2.25/lib/libapr-1.so.0
он дает разные результаты на CentOS и Archlinux. В Archlinux libdl.so вообще не отображается?
Откуда CentOS знает, что файлу нужен libdl.so.2?
CentOS 6.x:
# ls -la /software_pack/httpd-2.2.25/lib/libaprutil-1.so.0
lrwxrwxrwx 1 root root 21 Jul 30 09:47 /software_pack/httpd-2.2.25/lib/libaprutil-1.so.0 -> libaprutil-1.so.0.5.2
# ldd /software_pack/httpd-2.2.25/lib/libaprutil-1.so.0.5.2
linux-vdso.so.1 => (0x00007fffec400000)
libexpat.so.0 => /software_pack/httpd-2.2.25/lib/libexpat.so.0 (0x00007f5ec94d8000)
libapr-1.so.0 => /software_pack/httpd-2.2.25/lib/libapr-1.so.0 (0x00007f5ec92a8000)
librt.so.1 => /lib64/librt.so.1 (0x00007f5ec9098000)
libcrypt.so.1 => /lib64/libcrypt.so.1 (0x00007f5ec8e60000)
libpthread.so.0 => /lib64/libpthread.so.0 (0x00007f5ec8c40000)
libc.so.6 => /lib64/libc.so.6 (0x00007f5ec88a8000)
/lib64/ld-linux-x86-64.so.2 (0x00007f5ec9928000)
libfreebl3.so => /lib64/libfreebl3.so (0x00007f5ec8630000)
libdl.so.2 => /lib64/libdl.so.2 (0x00007f5ec8428000) <<<<<<<< Missing in arch
В Archlinux:
# ls -la /software_pack/httpd-2.2.25/lib/libaprutil-1.so.0
lrwxrwxrwx 1 root root 21 Jul 30 10:47 /software_pack/httpd-2.2.25/lib/libaprutil-1.so.0 -> libaprutil-1.so.0.5.2
# ldd /software_pack/httpd-2.2.25/lib/libaprutil-1.so.0.5.2
linux-vdso.so.1 (0x00007fff7cdd3000)
libexpat.so.0 => /software_pack/httpd-2.2.25/lib/libexpat.so.0 (0x00007f5aef4e7000)
libapr-1.so.0 => /software_pack/httpd-2.2.25/lib/libapr-1.so.0 (0x00007f5aef2ba000)
librt.so.1 => /usr/lib/librt.so.1 (0x00007f5aef084000)
libcrypt.so.1 => /usr/lib/libcrypt.so.1 (0x00007f5aeee4b000)
libpthread.so.0 => /usr/lib/libpthread.so.0 (0x00007f5aeec2d000)
libc.so.6 => /usr/lib/libc.so.6 (0x00007f5aee87f000)
/usr/lib64/ld-linux-x86-64.so.2 (0x00007f5aef934000)
dlopen
обычно предоставляется libdl.so.2
. В Arch Linux libdl.so.2
предоставляется glibc
пакет. Было бы очень странно, если бы у вас не было glibc
установлен, но все равно проверьте, есть ли у вас libdl.so.2
в вашей системе.
Вы также можете использовать readelf
команда для вывода таблицы символов для общего объекта и проверки, экспортируется ли конкретный символ:
readelf -Ws /usr/lib/libdl.so.2
Некоторая информация о том, почему ldd
вывод для одного и того же двоичного файла может отличаться в разных системах, можно найти здесь:
https://stackoverflow.com/questions/12714219/ldd-different-output-same-binary-different-distros