解决Linux下java.lang.UnsatisfiedLinkError问题

在基于Linux系统开发时,若牵扯到引用第三方产品的本地库文件,即.so文件时,经常会遇到下面异常:

at java.lang.ClassLoader$NativeLibrary.load(Native Method)

         at java.lang.ClassLoader.loadLibrary0(ClassLoader.java:1807)

         at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1732)

         at java.lang.Runtime.loadLibrary0(Runtime.java:823)

         at java.lang.System.loadLibrary(System.java:1028)

         ... 18 more

 

我在基于Hadoop1.0.4基础之上进行开发时,就多次遇到这个问题。

解决方案:

1. 以root账户,进入LinuxOS的/etc/ld.so.conf.d/目录下,创建一个文件,例如:xx-x86_64.conf,

    文件的内容为你引用的第三方产品的.so文件所在的目录路径,如:

    /home/kevin/xx/1.0/lib

    然后执行:ldconfig -v | more命令查看。

    推荐使用这种方案。

2. 进入/usr/lib64目录,分别创建.so文件的软连接,这种方案也可行,但当.so文件较多时,这种

    方式比较麻烦。

 

若进行上述配置之后,系统仍然提示该错误,比如在Hadoop下进行整合第三方产品时,这是需

要将第三方的.so文件Copy至$HADOOP_HOME/lib/native/Linux-amd64-64目录下,重启Hadoop

服务即可。

 

附:ldconfig命令作用

ldconfig是一个动态链接库管理命令。

为了让动态链接库为系统所共享,还需运行动态链接库的管理命令--ldconfig
ldconfig 命令的用途,主要是在默认搜寻目录(/lib和/usr/lib)以及动态库配置文件/etc/ld.so.conf内所列

的目录下,搜索出可共享的动态 链接库(格式如前介绍,lib*.so*),进而创建出动态装入程序(ld.so)所需

的连接和缓存文件.缓存文件默认为 /etc/ld.so.cache,此文件保存已排好序的动态链接库名字列表。

ldconfig通常在系统启动时运行,而当用户安装了一个新的动态链接库时,就需要手工运行这个命令.
ldconfig命令行用法如下:
ldconfig [-v|--verbose] [-n] [-N] [-X] [-f CONF] [-C CACHE] [-r ROOT] [-l] [-p|--print-cache] [-c FORMAT] [--format=FORMAT] [-V] [- |--help|--usage] path...


ldconfig可用的选项说明如下:
(1) -v或--verbose : 用此选项时,ldconfig将显示正在扫描的目录及搜索到的动态链接库,还有它所

     创建的连接的名字.
(2) -n : 用此选项时,ldconfig仅扫描命令行指定的目录,不扫描默认目录(/lib,/usr/lib),也不扫描配置

     文件/etc/ld.so.conf所列的目录.
(3) -N : 此选项指示ldconfig不重建缓存文件(/etc/ld.so.cache).若未用-X选项,ldconfig照常更新文

     件的连接.
(4) -X : 此选项指示ldconfig不更新文件的连接.若未用-N选项,则缓存文件正常更新.
(5) -f CONF : 此选项指定动态链接库的配置文件为CONF,系统默认为/etc/ld.so.conf.
(6) -C CACHE : 此选项指定生成的缓存文件为CACHE,系统默认的是/etc/ld.so.cache,此文件存放

     已排好序的可共享的动态链接库的列表.
(7) -r ROOT : 此选项改变应用程序的根目录为ROOT(是调用chroot函数实现的).选择此项时,系统

     默认的配置文件/etc/ld.so.conf,实际对应的为 ROOT/etc/ld.so.conf.如用-r /usr/zzz时,打开配置

    文件/etc/ld.so.conf时,实际打开的是/usr/zzz/etc/ld.so.conf文件.用此选项,可以 大大增加动态链

    接库管理的灵活性.
(8) -l : 通常情况下,ldconfig搜索动态链接库时将自动建立动态链接库的连接.选择此项时,将进入专

    家模式,需要手工设置连接.一般用户不用此项.
(9) -p或--print-cache : 此选项指示ldconfig打印出当前缓存文件所保存的所有共享库的名字.
(10) -c FORMAT 或 --format=FORMAT : 此选项用于指定缓存文件所使用的格式,共有三种: ld(老

    格式),new(新格式)和compat(兼容格式,此为默认格式).
(11) -V : 此选项打印出ldconfig的版本信息,而后退出.
(12) - 或 --help 或 --usage : 这三个选项作用相同,都是让ldconfig打印出其帮助信息,而后退出.

你可能感兴趣的:(linux)