加载共享库时出错;无法打开共享对象文件:没有这样的文件或目录

Error while loading shared libraries; cannot open shared object file: No such file or directory

我在 Ubuntu 操作系统 Ubuntu 上从 java class 加载共享库 (JNI) 时遇到问题

Exception in thread "main" java.lang.UnsatisfiedLinkError: /opt/ETcpsdk/lib/linux-x86_64/libjcryptoki.so: libcryptoki.so: cannot open shared object file: No such file or directory
    at java.lang.ClassLoader$NativeLibrary.load(Native Method)
    at java.lang.ClassLoader.loadLibrary1(ClassLoader.java:1965)
    at java.lang.ClassLoader.loadLibrary0(ClassLoader.java:1890)
    at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1880)
    at java.lang.Runtime.loadLibrary0(Runtime.java:849)
    at java.lang.System.loadLibrary(System.java:1088)
    at tutorialjni.Test.<clinit>(Test.java:7)

- Test.java

package tutorialjni;

public class Test {

    // Load an external library, called "jcryptoki"
    static {
        System.loadLibrary("jcryptoki");
    }

    public static void main(String[] args) {
        System.out.println(System.getProperty("java.library.path"));
    }

}

- LD_LIBRARY_PATH 在 /etc/environment

中分配
PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games"
JAVA_HOME="/opt/jdk1.7.0_75"
LD_LIBRARY_PATH="/opt/ETcpsdk/lib/linux-x86_64:/opt/ETcpsdk/lib/"

并且我拥有 ETcpsdk 文件夹。

- JDK版本:

java version "1.7.0_75"
Java(TM) SE Runtime Environment (build 1.7.0_75-b13)
Java HotSpot(TM) 64-Bit Server VM (build 24.75-b04, mixed mode)

- Ubuntu:

Distributor ID: Ubuntu
Description:    Ubuntu 14.04.2 LTS
Release:    14.04
Codename:   trusty

我将库目录添加到 ldconfig 缓存

你能帮帮我吗?

我遇到这个问题是因为我的共享库依赖于另一个工作不正常的共享库。

如果您在 Linux 中遇到此问题,通常有 3 个主要原因:

  1. 您的库取决于环境 PATH。

解决方案: 将您的路径变量设置为 .bashrc 以便它在启动时加载。 重启 Linux 或 运行 。 ~/.bashrc.

  1. 符号库文件 link 已损坏。 Linux 应用程序过去常常在集中位置创建符号文件 link,而不是将它们指向专用路径中的实际文件。

解决方法:检查你的库文件是否以link存在,是否指向有效文件。

  1. 用户访问权限不足。

当我的 Web 应用程序在 Linux 中由访问权限不足的登录用户启动时,我遇到了这个错误。此错误通常紧随其他错误/异常,尤其是来自您的应用程序服务器,即 Tomcat:

org.apache.catalina.LifecycleException: Failed to initialize component ...

org.hibernate.engine.jdbc.internal.LobCreatorBuilder - HHH000424: Disabling contextual LOB creation as createClob() method threw error : java.lang.reflect.InvocationTargetException

解决方法: 停止您的网络/应用程序服务器当前实例。 使用超级用户或具有足够访问权限的用户登录,即 root 重新启动服务器或再次调用之前的函数。