我有一个 3rd 方二进制库,用于通过 SSL 连接到服务器,该库在Cent OS 4 32-bit上运行良好,但在Debian Lenny 32-bit上尝试处理事务时出现 SSL 初始化错误。
当我ldd
在 Debian 上的库上执行时,缺少ldd
Cent OS 上的 5 个链接:
libgssapi_krb5.so.2 => /usr/lib/libgssapi_krb5.so.2
libkrb5.so.3 => /usr/lib/libkrb5.so.3
libcom_err.so.2 => /lib/libcom_err.so.2
libk5crypto.so.3 => /usr/lib/libk5crypto.so.3
libresolv.so.2 => /lib/libresolv.so.2
我怀疑我的问题出在这里。所有这些库都安装在 Debian 系统上,所以我很困惑第 3 方二进制文件看不到它们。
我已经在每个系统上的第 3 方二进制文件上做了一个 md5sum,它们完全一样。
以下是 Cent OS 的完整ldd
列表:
[root@localhost ~]# ldd /usr/lib/libwebpayclient.so
libssl.so.4 => /lib/libssl.so.4 (0x0026a000)
libcrypto.so.4 => /lib/libcrypto.so.4 (0x00c41000)
libstdc++.so.5 => /usr/lib/libstdc++.so.5 (0x00544000)
libm.so.6 => /lib/tls/libm.so.6 (0x0093e000)
libgcc_s.so.1 => /lib/libgcc_s.so.1 (0x00da4000)
libc.so.6 => /lib/tls/libc.so.6 (0x0066e000)
libgssapi_krb5.so.2 => /usr/lib/libgssapi_krb5.so.2 (0x008dd000)
libkrb5.so.3 => /usr/lib/libkrb5.so.3 (0x00394000)
libcom_err.so.2 => /lib/libcom_err.so.2 (0x00111000)
libk5crypto.so.3 => /usr/lib/libk5crypto.so.3 (0x00114000)
libresolv.so.2 => /lib/libresolv.so.2 (0x007da000)
libdl.so.2 => /lib/libdl.so.2 (0x00135000)
libz.so.1 => /usr/lib/libz.so.1 (0x004d1000)
/lib/ld-linux.so.2 (0x008b5000)
请注意,我必须安装包 compat-libstdc++-33.i386 才能解析 libstdc++.so.5
这是ldd
来自 Debian 的完整列表:
localhost:~# ldd /usr/lib/libwebpayclient.so
linux-gate.so.1 => (0xb7fcb000)
libssl.so.4 => not found
libcrypto.so.4 => not found
libstdc++.so.5 => /usr/lib/libstdc++.so.5 (0xb7ee5000)
libm.so.6 => /lib/i686/cmov/libm.so.6 (0xb7ebf000)
libgcc_s.so.1 => /lib/libgcc_s.so.1 (0xb7eb2000)
libc.so.6 => /lib/i686/cmov/libc.so.6 (0xb7d57000)
/lib/ld-linux.so.2 (0xb7fcc000)
请注意,我必须安装包 libstdc++5 才能解析 libstdc++.so.5。
用于ln -s
修复我得到的 2 个“未找到”链接:
localhost:~# ldd /usr/lib/libwebpayclient.so
linux-gate.so.1 => (0xb7eff000)
libssl.so.4 => /usr/lib/libssl.so.4 (0xb7e8e000)
libcrypto.so.4 => /usr/lib/libcrypto.so.4 (0xb7d31000)
libstdc++.so.5 => /usr/lib/libstdc++.so.5 (0xb7c76000)
libm.so.6 => /lib/i686/cmov/libm.so.6 (0xb7c50000)
libgcc_s.so.1 => /lib/libgcc_s.so.1 (0xb7c43000)
libc.so.6 => /lib/i686/cmov/libc.so.6 (0xb7ae8000)
libdl.so.2 => /lib/i686/cmov/libdl.so.2 (0xb7ae4000)
libz.so.1 => /usr/lib/libz.so.1 (0xb7acf000)
/lib/ld-linux.so.2 (0xb7f00000)
有趣的是,libz.so.1 出现了。于是就有了线索。
Cent OS 上的 SSL 版本是 0.9.7a,而 Debian 上是 0.9.8。我敢打赌它链接到更少的图书馆......