将导出的 Java 项目从开发计算机移至生产环境后,我遇到了麻烦。
java项目(一个Eclipse插件)有一个我写的JNI库,它依赖于一个开源库,而这个库又依赖于Boost。我在我的 SLES11 机器上编译了所有内容,包括 Boost,并且该程序可以正常运行。
当我将程序移动到另一台机器时,出现错误:
java.lang.UnsatisfiedLinkError:/path/to/project/lib/libMyJNI.so: libboost_system.so.1.67.0: cannot open shared object file: No such file or directory
我将所需的库复制到同一目录中。ldd libMyJNI.so
列出了 20 个依赖项,但解决了所有这些依赖项。
我仍然遇到同样的错误。
我假设java.library.path
已正确设置,因为它尝试加载libMyJNI.so
并认识到依赖性。
我是否正确地期待如果ldd
有效,java应该解决依赖关系吗?
有什么线索吗?
谢谢你!
编辑:这是 ldd 的输出ldd libMyJNI.so
linux-vdso.so.1 => (0x00007fffa59ff000)
libboost_system.so.1.67.0 (0x00007fc427bce000)
libboost_filesystem.so.1.67.0 (0x00007fc4279b4000)
libboost_thread.so.1.67.0 (0x00007fc42778f000)
libboost_date_time.so.1.67.0 (0x00007fc42757a000)
libboost_iostreams.so.1.67.0 (0x00007fc42735f000)
libboost_serialization.so.1.67.0 (0x00007fc42710f000)
libboost_chrono.so.1.67.0 (0x00007fc426f06000)
libboost_atomic.so.1.67.0 (0x00007fc426d04000)
libboost_regex.so.1.67.0 (0x00007fc426a00000)
libpcl_common.so.1.8 (0x00007fc42673b000)
libpcl_io.so.1.8 (0x00007fc4263cb000)
libpcl_octree.so.1.8 (0x00007fc425fdc000)
libstdc++.so.6 => /usr/lib64/libstdc++.so.6 (0x00007fc425c98000)
libm.so.6 => /lib64/libm.so.6 (0x00007fc425a42000)
libgcc_s.so.1 => /lib64/libgcc_s.so.1 (0x00007fc42582b000)
libc.so.6 => /lib64/libc.so.6 (0x00007fc4254cc000)
librt.so.1 => /lib64/librt.so.1 (0x00007fc4252c3000)
libpthread.so.0 => /lib64/libpthread.so.0 (0x00007fc4250a6000)
libz.so.1 => /lib64/libz.so.1 (0x00007fc424e8f000)
libgomp.so.1 => /usr/lib64/libgomp.so.1 (0x00007fc424c86000)
libpcl_io_ply.so.1.8 (0x00007fc424a21000)
libpng12.so.0 => /usr/lib64/libpng12.so.0 (0x00007fc4247f9000)
/lib64/ld-linux-x86-64.so.2 (0x00007fc427fe8000)
感谢@user2543253 我已经解决了这个问题。我正在为以后的读者(包括我,当我遇到同样的问题时)给出答案。
java.library.path
设置正确,因为它可以加载JNI库。其他库(依赖项)必须位于列出的目录中LD_LIBRARY_PATH
。因此,在部署软件时,您可以
- 将依赖项安装在通常存在的位置
LD_LIBRARY_PATH
or
- 将目录附加到
LD_LIBRARY_PATH
在启动插件之前。
ldd
可以成功链接库,因为它也在当前目录中查找。所以ldd libMyJNI.so
可以成功,同时ldd \path\to\libMyJNI.so
可能会失败。在这种情况下,JNI 将不起作用。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)