Linux从error while loading shared libraries: libxxx.so.x 错误的常规解决思路看程序与动态库的关系

出现这类错误的原因通常是动态库无法被加载,本文介绍了常规的解决方案,适用多种情况;
创作不易,如果本文帮到了您;
如果本文帮到了您,请帮忙点个赞 👍👍👍;
如果本文帮到了您,请帮忙点个赞 👍👍👍;
如果本文帮到了您,请帮忙点个赞 👍👍👍;

1 前言

ubuntu 系统下安装了程序,但是运行的时候出现 error while loading shared libraries: libGL.so.1 的错误,基本上可以知道是GL动态库没有被正确加载,基本上这种问题的解决思路如下;

  • 寻找本地是否已经存在错误提示中的动态库;若没有找到,则需要自行安装相应版本的动态库;
  • 配置ldconfig即可,这里涉及到linux下程序是如何寻找动态库;

注意
注意
注意

注意:寻找解决方案可以直接查看第三节,亲测有效;第二节比比赖赖,但是对其中的原理进行了剖析,感兴趣的也可以看一下。

2 程序是如何搜索到动态库的?

这里我们有必要了解一下一个程序的运行是如何搜索到所需要的动态库,以便于理解后面具体的解决方案,但是由于篇幅较短,这里点到即止,只给出关键部分。
首先一个程序运行的整体过程如下;

  • 0 程序运行–>
  • 1 加载ld-linux.so.2–>
  • 2 搜索动态库路径–>
  • 3 在相应路径下根据动态链接表搜索动态库 –>
  • 4 搜索相应符号链接加载至内存执行->
  • 运行成功

整理成流程图如下图所示;

Created with Raphaël 2.2.0打开程序1 加载 ld-linux.so.22 搜索动态库路径3 在相应路径下根据动态链接表搜索动态库缺少相应库?提示错误4 搜索相应符号链接加载至内存执行加载成功?开始运行yesnoyesno

以此我们大概可以分析出,一般无法找到动态库的原因基本有两点:

  • 本地缺少相应动态库;
  • 动态库真实路径不存在路径搜索表中;

2.1 ldd 指令

ldd命令可以打印出当前出现所依赖的动态链接库;
可以通过man ldd了解其如何使用;
在这里插入图片描述

本文以wireshark为例进行介绍,先找到wireshark的安装路径以及查看它的动态库依赖表;

Jackma@albaba:find / -name wireshark
/usr/share/doc/wireshark
/usr/share/wireshark
/usr/lib/x86_64-linux-gnu/wireshark
/usr/bin/wireshark
/root/.config/wireshark
/etc/wireshark
Jackma@albaba:ldd /usr/bin/wireshark

具体如下所示;
在这里插入图片描述
找一下依赖库里有没有libGL

ldd /usr/bin/wireshark | grep libGL

在这里插入图片描述
有所发现,最终程序是要寻找/usr/lib/x86_64-linux-gnu/mesa/libGL.so.1

ls -l /usr/lib/x86_64-linux-gnu/mesa/libGL.so.1

结果如下所示;动态库存在;
在这里插入图片描述

2.2 ldconfig

ldconfig的使用直接看man page截图如下所示;
在这里插入图片描述
可以看到,ldconfig的作用是在受信任的目录下创建指向的最新共享库的必要链接和缓存;
通常这些路径包括;

  • /lib/usr/lib,这些一般是系统默认的链接库;
  • /etc/ld.so.conf,通常动态库搜索路径的文件还会放在/etc/ld.so.conf.d/下;
ls -l /etc/ld.so.conf.d/

在这里插入图片描述
因此只要将libGL.so.1所在路径**/usr/lib/x86_64-linux-gnu/mesa/**添加到其中.conf文件中即可,
然后运行ldconfig更新缓存。之后再运行程序,发现就开业正常运行了。

3 解决方案

**现象:**在终端运行程序 如,wireshark;
出现报错:error while loading shared libraries: libGL.so.1
关键字: libGL.so.1
解决办法:

找到程序wireshark所在路径;

sudo find / -name wireshark

找到库libGL.so.1所在路径;

sudo ldd /usr/bin/wireshark | grep libGL.so.1

在这里插入图片描述
添加库路径;

sudo echo /usr/lib/x86_64-linux-gnu/mesa/ > /etc/ld.so.conf.d/mesa.conf 
sudo ldconfig

完成以上操作,程序就可以正常运行了。

4 总结

本文简单解决了程序无法链接到动态库的问题,并且介绍了两者之间的紧密联系,笔者能力有限,难免存在错误和纰漏,请大佬不吝赐教。

创作不易,如果本文帮到了您;
如果本文帮到了您,请帮忙点个赞 👍👍👍;
如果本文帮到了您,请帮忙点个赞 👍👍👍;
如果本文帮到了您,请帮忙点个赞 👍👍👍;

posted @ 2020-03-25 21:24  小麦大叔  阅读(1359)  评论(0编辑  收藏  举报