JNI не может найти общую библиотеку после развертывания программы

У меня возникают проблемы после переноса экспортированного проекта Java с компьютера разработчика на производство.

Проект java (плагин Eclipse) имеет библиотеку JNI, написанную мной, которая зависит от библиотеки с открытым исходным кодом, которая, в свою очередь, зависит от Boost. Я собрал все, включая Boost, на моем компьютере SLES11, и программа просто работает.

Когда я перемещаю программу на другой компьютер, я получаю сообщение об ошибке:

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)

1 ответ

Решение

Благодаря @user2543253 я решил проблему. Я даю ответ для читателей в будущем (включая меня, когда у меня будет такая же проблема).

java.library.path был правильно установлен, потому что он мог загрузить библиотеку JNI. Другие библиотеки (зависимости) должны находиться в каталоге, указанном в LD_LIBRARY_PATH, Поэтому при развертывании программного обеспечения вы можете

  • установить зависимости в местах, обычно присутствующих в LD_LIBRARY_PATH или же
  • добавить каталог в LD_LIBRARY_PATH перед запуском плагина.

ldd может быть успешным в связывании библиотеки, потому что она также ищет в текущем каталоге. Так ldd libMyJNI.so может быть успешным в то время как ldd \path\to\libMyJNI.so может потерпеть неудачу. В этом случае JNI не будет работать.

Другие вопросы по тегам