error while loading shared libraries: xxx.so.x 错误的原因和解决办法

  • Post author:
  • Post category:其他


原因

1.系统共享库没有这个文件或者这个文件的版本不对

确认方法 find / -name xxx.so.x (共享库提示缺失的文件名称) 找不到即可确认

解决方法 网上下载到这个文件 进行安装

2.文件存在 但系统加载不到

解决方法:

1.将共享库文件安装时注意 需要安装到 /lib 或 /usr/lib 目录下 然后让共享库文件加载到共享库中去 输入命令 ldconfig

2若找到缺失文件在别处 可以参考 文章末尾 ldconfig需要注意事项:



更新配置命令:



/sbin/ldconfig –v

注意 /usr/local/lib 在开源项目中 很多共享库都会在这个目录下

共享库配置文件:/etc/ld.so.conf 中应该加入 /usr/local/lib

若文件存在但是 是高版本 可以使用软连接的方式

比如 缺失so.6 但找到啦 so.8

查到存在so.8 即因为高版本兼容低版本的缘故

可以利用

ln -s xxx/…/xxx/so.8 xxx/…/xxx/so.6



ldconfig是一个动态链接库管理命令,其目的为了让动态链接库为系统所共享。



ldconfig的主要用途:

默认搜寻/lilb和/usr/lib,以及配置文件/etc/ld.so.conf内所列的目录下的库文件。

库文件的格式为:lib***.so.**,进而创建出动态装入程序(ld.so)所需的连接和缓存文件。

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



ldconfig通常在系统启动时运行,而当用户安装了一个新的动态链接库时,就需要手工运行这个命令

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打印出其帮助信息,而后退出.、



ldconfig需要注意的事项:

1、往/lib和/usr/lib里面加东西,是不用修改/etc/ld.so.conf文件的,但是添加完后需要调用下ldconfig,不然添加的library会找不到。

2、如果添加的library不在/lib和/usr/lib里面的话,就一定要修改/etc/ld.so.conf文件,往该文件追加library所在的路径,然后也需要重新调用下ldconfig命令。


比如在安装MySQL的时候,其库文件/usr/local/mysql/lib,就需要追加到/etc/ld.so.conf文件中。命令如下:

#echo “/usr/local/mysql/lib” >> /etc/ld.so.conf

#ldconfig -v | grep mysql


3、如果添加的library不在/lib或/usr/lib下,但是却没有权限操作写/etc/ld.so.conf文件的话,这时就需要往export里写一个全局变量LD_LIBRARY_PATH,就可以了。

利用mysql 举例:

export LD_LIBRARY_PATH=/usr/local/mysql/lib:$LD_LIBRARY_PATH

案例:


Apr 08 11:48:31 DNSSERVER01 crond[3460]: /usr/sbin/sendmail: error while loading shared libraries: libmysqlclient.so.18: cannot open shared object file: No





such file or directory





发现缺少libmysqlclient.so.18

[root@DNSSERVER01 network-scripts]# cd /usr/lib

[root@DNSSERVER01 lib]# ls libmysqlclient*

ls: cannot access libmysqlclient*: No such file or directory

[root@DNSSERVER01 lib]# ls /usr/local/mysql/lib/libmysqlclient.so.18

ls: cannot access /usr/local/mysql/lib/libmysqlclient.so.18: No such file or directory

[root@DNSSERVER01 lib]# ls /usr/local/mysql/lib/libmysqlclient*

/usr/local/mysql/lib/libmysqlclient.a

/usr/local/mysql/lib/libmysqlclient.so /usr/local/mysql/lib/libmysqlclient.so.20

/usr/local/mysql/lib/libmysqlclient.so.20.3.11

发现自己系统里的是libmysqlclient.so.20

做软连接

[root@DNSSERVER01 lib]# ln -s /usr/local/mysql/lib/libmysqlclient.so.20 /usr/lib

[root@DNSSERVER01 lib]# service crond restart

Redirecting to /bin/systemctl restart crond.service

[root@DNSSERVER01 lib]# service crond status

Redirecting to /bin/systemctl status crond.service

● crond.service – Command Scheduler

Loaded: loaded (/usr/lib/systemd/system/crond.service; enabled; vendor preset: enabled)

Active: active (running) since Mon 2019-04-08 11:52:35 CST; 5s ago

Main PID: 9052 (crond)

CGroup: /system.slice/crond.service

└─9052 /usr/sbin/crond -n

Apr 08 11:52:35 DNSSERVER01 systemd[1]: Started Command Scheduler.

Apr 08 11:52:35 DNSSERVER01 crond[9052]: (CRON) INFO (RANDOM_DELAY will be scaled with factor 76% if used.)

Apr 08 11:52:35 DNSSERVER01 crond[9052]: (CRON) INFO (running with inotify support)

Apr 08 11:52:35 DNSSERVER01 crond[9052]: (CRON) INFO (@reboot jobs will be run at computer’s startup.)

输入ldconfig让重新加载配置文件



版权声明:本文为ADCadc123456789原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。