红联Linux门户
Linux帮助

关于程序运行时加载动态库失败的解决方法

发布时间:2015-10-31 14:58:35来源:linux网站作者:linux_zhu

错误提示如下:

error while loading shared libraries: libjson.so.0: cannot open shared object file: No such file or directory 

原因一般有两个,一个是操作系统中没有包含该共享库(lib*.so.* 文件)或者共享库版本不对。解决办法就是重新下载安装。


另外一个原因就是已经安装了该共享库,但是执行需要调用该共享库的程序的时候,程序按照默认共享库路径找不到该共享库文件。解决方法如下:


如果共享库文件安装到了 /lib 或 /usr/lib 目录下,那么执行一下 ldconfig 命令。
ldconfig命令的用途, 主要是在默认搜寻目录(b和/usrb)以及动态库配置文件/etc/ld.so.conf内所列的目录下, 搜索出可共享的动态链接库(格式如lib*.so*), 进而创建出动态装入程序(ld.so)所需的连接和缓存文件. 缓存文件默认为/etc/ld.so.cache, 此文件保存已排好序的动态链接库名字列表.  


如果共享库文件安装到了 /usr/local/lib (一般开源的共享库都会安装到该目录下)或者其它非 /lib 或 /usr/lib 目录下,那么在执行 ldconfig 命令前,还要把新的共享库目录加入到共享库配置文件 /etc/ld.so.conf 中,如下:

# cat /etc/ld.so.conf 
include ld.so.conf.d/*.conf 
# echo "/usr/local/lib" >> /etc/ld.so.conf 
# ldconfig 

或者在 /etc/ld.so.conf.d/ 目录下新建任何以 .conf 为后缀的文件,在该文件中加入库文件所在的目录。然后执行 ldconfig 更新 /etc/ld.so.cache 文件。


如果共享库文件安装到了其他非 /lib 或 /usr/lib 目录下,但是又不想在 /etc/ld.so.conf 文件中加共享库路径(或者是没有权限加路径)。那可以 export 一个全局变量 LD_LIBRARY_PATH,然后运行程序的时候就会去找个目录中找共享库。

LD_LIBRARY_PATH的意思是告诉loader在哪些目录中可以找到共享库. 可以设置多个搜索目录, 这些目录之间用冒号分隔开. 比如安装了一个mysql到/usr/local/mysql目录下, 其中有一大堆库文件在/usr/local/mysql/lib下面, 则可以在.bashrc或.bash_profile或shell里加入以下语句即可: 
 
export LD_LIBRARY_PATH=/usr/local/mysql/lib:$LD_LIBRARY_PATH     
 
一般来讲这只是一种临时的解决方案, 在没有权限或临时需要的时候使用. 


如果程序需要的库文件比系统目前存在的库文件版本低,可以做一个链接。比如:

error while loading shared libraries: libncurses.so.4: cannot open shared 
object file: No such file or directory 

ls /usr/lib/libncu* 
/usr/lib/libncurses.a   /usr/lib/libncurses.so.5 
/usr/lib/libncurses.so  /usr/lib/libncurses.so.5.3 

可见虽然没有libncurses.so.4,但有libncurses.so.5,是可以向下兼容的 
建一个链接就好了 
ln -s  /usr/lib/libncurses.so.5.3  /usr/lib/libncurses.so.4


从Linux and Windows的动态库中引入类://m.ajphoenix.com/linux/9242.html

Linux调试动态库://m.ajphoenix.com/linux/7842.html

Linux下静态库与动态库的生成与调用://m.ajphoenix.com/linux/6243.html

Linux中如何创建静态库和动态库://m.ajphoenix.com/linux/602.html