错误解决error while loading shared libraries: libXXX.so.X: cannot open shared object file: No such file

本文介绍了解决Ubuntu系统中使用VMware环境下库文件链接失败的问题,通过修改配置文件并利用ldconfig命令来更新缓存,使得编译器能够正确找到所需的库文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前提:ubuntu-debug机器上向SVN提交了pdu-IVT,想在别的普通机器上验证直接make能否成功,编译出的用户程序能否运行。


工作PC机上装有VMware,里面的ubuntu版本跟ubuntu-debug机器上相同,都是ubuntu 11.10版本。

VMware的家目录下有个目录pdu-IVT,是从SVN上更新出来之后,直接拷贝过来的。


在将ubuntu-debug机器上,make能成功,并且生成的二进制可执行程序pdu也能运行,并与switch成功建立连接;

但在工作PC机的VMware中,运行make时,提示错误:

/usr/bin/ld: cannot find -lCiscoEnergyWiseSdk
collect2: ld returned 1 exit status
make: *** [pdu] Error 1
分析原因:ld提示找不到库文件,而库文件就在当前目录中。

链接器ld默认的目录是/lib和/usr/lib,如果放在其他路径也可以,需要让ld知道库文件在哪里。

方法1:

编辑/etc/ld.so.conf文件,在新的一行中加入库文件所在目录;

运行ldconfig,以更新/etc/ld.so.cache文件;

方法2:

在/etc/ld.so.conf.d/目录下新建任何以.conf为后缀的文件,在该文件中加入库文件所在的目录;

运行ldconfig,以更新/etc/ld.so.cache文件;


本人觉得第二种办法更为方便,对于原系统的改动最小。因为/etc/ld.so.conf文件的内容是include /etc/ld.so.conf.d/*.conf

所以,在/etc/ld.so.conf.d/目录下加入的任何以.conf为后缀的文件都能被识别到。

本人的作法:
1. 将所有的用户需要用到的库放到/usr/loca/lib;
2. 在/etc/ld.so.conf.d/目录下新建文件usr-libs.conf,内容是:/usr/local/lib
3. #sudo ldconfig

ld.so.cache的更新是递增式的,就像PATH系统环境变量一样,不是从头重新建立,而是向上累加。

除非重新开机,才是从零开始建立ld.so.cache文件。


### 解决 `error while loading shared libraries: libz.so.1` 错误 当遇到 `error while loading shared libraries: libz.so.1: cannot open shared object file: No such file or directory` 的错误时,这通常意味着系统缺少所需的动态链接库文件。以下是几种可能的解决方案: #### 安装缺失的依赖包 如果是在基于 Red Hat 或 CentOS 的系统上运行,则可以通过安装相应的 RPM 包来解决问题。可以尝试使用以下命令来安装压缩工具包及其开发头文件: ```bash sudo yum install zlib-devel ``` 对于 Debian 或 Ubuntu 系统,应该使用 apt-get 来代替 yum: ```bash sudo apt-get update && sudo apt-get install zlib1g-dev ``` #### 验证并修复已损坏或不完整的软件包 有时现有的软件包可能会被破坏或者未完全安装好,在这种情况下,重新安装这些有问题的软件包也可能有助于解决问题。 #### 设置环境变量 LD_LIBRARY_PATH 另一种方法是通过设置 `LD_LIBRARY_PATH` 环境变量指向包含所需 `.so` 文件的位置。假设已经手动下载并将 `libz.so.1` 放置到了 `/usr/local/lib/` 下面,那么可以在终端里输入如下指令临时生效此路径: ```bash export LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH ``` 为了使更改永久化,可将上述语句添加到用户的 shell profile 文件(如 ~/.bashrc 或者 ~/.profile)中去[^1]。 #### 使用 ldd 命令排查问题 还可以利用 Linux 自带的一个叫做 `ldd` 的实用程序来查看具体哪个共享库丢失了以及它期望在哪里找到它们。例如,针对某个二进制文件 foo 可以这样做: ```bash ldconfig -p | grep libz.so.1 ldd ./foo ``` 以上措施应当能够帮助定位和解决由于找不到特定版本的 `libz.so.1` 所引发的各种应用程序启动失败的情况[^3]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值