我创建了一个app(api_tests),它使用链接到oracle occi库(libocci.so.12.1)的库(libstorage.so)并编译它。 当我运行这个应用程序时,我收到一个错误:
api_tests
api_tests: symbol lookup error: ./libstorage.so: undefined symbol: _ZN6oracle4occi11Environment17createEnvironmentENS1_4ModeEPvPFS3_S3_mEPFS3_S3_S3_mEPFvS3_S3_E
但是,带有此符号的库存在于当前目录中:
ls | grep libocci
libocci.so*
libocci.so.11.1*
libocci.so.12.1*
nm libocci.so.12.1 | grep _ZN6oracle4occi11Environment17createEnvironmentENS1_4ModeEPvPFS3_S3_mEPFS3_S3_S3_mEPFvS3_S3_E
0000000000097e70 T _ZN6oracle4occi11Environment17createEnvironmentENS1_4ModeEPvPFS3_S3_mEPFS3_S3_S3_mEPFvS3_S3_E
0000000000125014 r _ZN6oracle4occi11Environment17createEnvironmentENS1_4ModeEPvPFS3_S3_mEPFS3_S3_S3_mEPFvS3_S3_E$$LSDA
当前路径被添加到LD_LABRARY_PATH:
echo $LD_LIBRARY_PATH
./:/usr/vacpp/bin/../lib:/lib
我想知道我的库有什么问题以及我如何调试这个问题?
更新: 看起来这个库没有链接(至少ldd没有显示这种依赖)。我想这是makefile中的错误,它已经编译但在运行时失效。
答案 0 :(得分:2)
nm libocci.so.12.1
上述命令有两个问题:
libocci.so.12.1
是否实际上已加载到您的流程中。要回答"哪个libocci已加载",请使用LD_DEBUG=libs
运行。libocci.so.12.1
的符号表中存在符号并不意味着它可用于动态链接。 动态符号表中必须可用,您可以使用nm -D libocci.so.12.1