ldd 是最直接有效的 linux 动态库缺失诊断 工具,通过分析二进制依赖关系定位“找不到库”“版本不对”“路径未配置”等问题,输出中“not found”表示系统在默认路径中未找到对应库。

Linux 动态库缺失时,ldd 是最直接有效的诊断 工具 。它不运行程序,只分析二进制文件依赖的共享库路径和加载状态,帮你快速定位“找不到库”“版本不对”“路径未配置”等 常见问题。
用 ldd 查清到底缺哪个库
执行 ldd /path/to/your/program,输出中出现 “not found” 的行就是缺失的库。注意:不是所有“not found”都代表真缺失——比如 libpthread.so.0 => not found 可能只是符号链接没建好,而 libopencv_core.so.4.5 => not found 才是典型缺失。
- 如果某库显示 “=> not found”,说明系统在默认路径(
/lib,/usr/lib,/usr/local/lib等)里完全找不到它 - 如果显示 “=> /some/path/libxxx.so (0x…)”,说明已找到,但后续仍报错,可能是版本不兼容或 ABI 不匹配
- 若提示 “you do not have execution permission”,先检查文件权限:
chmod +x
确认库文件是否存在且可访问
根据 ldd 提示的库名(如 libz.so.1),用 find 或 locate 搜索:
find /usr -name "libz.so*" 2>/dev/NULL-
locate libz.so.1(需先updatedb)
若找到类似 /usr/lib/x86_64-linux-gnu/libz.so.1.2.11,但 ldd 仍显示 not found,大概率是软链接断了。检查并重建:
-
ls -l /usr/lib/x86_64-linux-gnu/libz.so.1(看是否指向真实文件) - 若失效,用
sudo ln -sf libz.so.1.2.11 libz.so.1修复
让系统“看得到”你装的库
自己编译安装的库(如放在 /opt/myapp/lib)默认不在搜索路径中。有三种常用方式让 ldd 和运行时识别它:
- 临时生效:运行前设置
LD_LIBRARY_PATH=/opt/myapp/lib:$LD_LIBRARY_PATH - 永久生效(推荐):在
/etc/ld.so.conf.d/myapp.conf中写入路径,再执行sudo ldconfig - 打包进可执行文件 :编译时加
-Wl,-rpath,/opt/myapp/lib,这样ldd会显示该路径且无需 环境变量
区分“找不到”和“加载失败”
ldd 显示正常(有路径、有地址),但程序启动仍报 undefined symbol 或 cannot open shared Object file,说明问题不在查找阶段,而在加载或兼容性层面:
- 用
objdump -T your_lib.so | grep symbol_name确认符号是否存在 - 用
readelf -d your_program | grep NEEDED看程序声明依赖的库名是否拼写一致(注意大小写、版本后缀) - 不同 glibc 版本间不兼容?尝试在同版本系统上编译,或用
patchelf --set-interpreter替换解释器(慎用)
不复杂但容易忽略:每次改完库路径或软链接,记得运行 ldconfig 刷新缓存;ldd 结果只是静态分析,最终能否运行还要看实际加载时的权限、架构(32/64 位)、glibc 兼容性。