Programm mit zwei Versionen derselben Bibliothek verknüpft?

Programm mit zwei Versionen derselben Bibliothek verknüpft?

Ich habe zwei Systeme, auf denen Debian Jessie 8.4 läuft, und auf beiden ist Open-VM-Tools installiert. Die Dateien sind auf beiden Seiten identisch. Auf einer Seite verweist vmtoolsd jedoch auf eine alte Libicu, obwohl die Dateien identisch sind, was mir Folgendes gibt:

vmtoolsd: error while loading shared libraries: libicui18n.so.44: cannot open shared object file: No such file or directory

Hier ist die ldd-Ausgabe auf dem fehlerhaften Server:

root@asterisk:/usr/lib/x86_64-linux-gnu#   ldd /usr/bin/vmtoolsd
        linux-vdso.so.1 (0x00007ffec070c000)
        libvmtools.so.0 => /usr/local/lib/libvmtools.so.0 (0x00007fed5ba5e000)
        libgmodule-2.0.so.0 => /usr/lib/x86_64-linux-gnu/libgmodule-2.0.so.0 (0x00007fed5b85a000)
        libgobject-2.0.so.0 => /usr/lib/x86_64-linux-gnu/libgobject-2.0.so.0 (0x00007fed5b607000)
        libgthread-2.0.so.0 => /usr/lib/x86_64-linux-gnu/libgthread-2.0.so.0 (0x00007fed5b405000)
        libglib-2.0.so.0 => /lib/x86_64-linux-gnu/libglib-2.0.so.0 (0x00007fed5b0f6000)
        libicui18n.so.52 => /usr/lib/x86_64-linux-gnu/libicui18n.so.52 (0x00007fed5ace4000)
        libicuuc.so.52 => /usr/lib/x86_64-linux-gnu/libicuuc.so.52 (0x00007fed5a966000)
        libicudata.so.52 => /usr/lib/x86_64-linux-gnu/libicudata.so.52 (0x00007fed590f9000)
        libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007fed58dee000)
        libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007fed58aed000)
        libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007fed588d7000)
        libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007fed586ba000)
        libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fed5830f000)
        librt.so.1 => /lib/x86_64-linux-gnu/librt.so.1 (0x00007fed58107000)
        libcrypt.so.1 => /lib/x86_64-linux-gnu/libcrypt.so.1 (0x00007fed57ed0000)
        libicui18n.so.44 => not found
        libicuuc.so.44 => not found
        libicudata.so.44 => not found
        libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007fed57ccc000)
        libffi.so.6 => /usr/lib/x86_64-linux-gnu/libffi.so.6 (0x00007fed57ac4000)
        libpcre.so.3 => /lib/x86_64-linux-gnu/libpcre.so.3 (0x00007fed57856000)
        /lib64/ld-linux-x86-64.so.2 (0x00007fed5bced000)

Nur auf diesem System verlinkt es nicht nur auf libicui18n.so.52, sondern AUCH auf libicui18n.so.44 ?!?! Das andere System hat diese seltsame Abhängigkeit nicht. Ich habe libicu52 und open-vm-tools bereits neu installiert. Die Datei libicui18n.so.4 kann nirgendwo auf dem Server gefunden werden.

Was könnte der Grund für dieses Verhalten sein?

Antwort1

Sie nehmen auf /usr/local/lib/libvmtools.so.0, was vermutlich ein Überbleibsel eines Builds ist, das auf Debian 6 (das hatte libicu44) erstellt wurde. Wenn Sie das umbenennen, vmtoolsdsollte es seine Bibliotheken richtig finden.

verwandte Informationen