AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 511380
Accepted
daedalus_hamlet
daedalus_hamlet
Asked: 2019-04-09 22:48:41 +0800 CST2019-04-09 22:48:41 +0800 CST 2019-04-09 22:48:41 +0800 CST

为什么 Unix/Linux 系统不遍历目录,直到找到所需的链接库版本?

  • 772

我有一个名为“alpha”的二进制可执行文件,它需要一个链接库(libz.so.1.2.7),它位于/home/username/myproduct/lib/libz.so.1.2.7

在通过执行以下命令生成我的二进制可执行文件之前,我将其导出到我的终端实例。

export LD_LIBRARY_PATH=/home/username/myproduct/lib/:$LD_LIBRARY_PATH

现在,当我生成另一个需要相同库但版本不同的应用程序“bravo”时,即 (libz.so.1.2.8) 可用 /lib/x86_64-linux-gnu/libz.so.1.2.8,系统会抛出以下错误。

version `ZLIB_1.2.3.3' not found (required by /usr/lib/x86_64-linux-gnu/libxml2.so.2)

如果我取消设置LD_LIBRARY_PATH,“bravo”启动正常。我了解上述行为是因为LD_LIBRARY_PATH在查找链接库时优先于定义的目录路径/etc/ld.so.conf,因此发生了上述错误。我只是好奇为什么UNIX / LINUX的开发人员没有设计操作系统来根据层次结构搜索其他目录中的链接库,如果库的第一个实例是不同的版本。

简单地说,UNIX/LINUX 系统遍历一组目录,直到找到所需的库。但是,为什么它在找到预期版本之前不做同样的事情,而不是接受库的第一个实例而不管其版本如何?

libraries dynamic-linking
  • 1 1 个回答
  • 2425 Views

1 个回答

  • Voted
  1. Best Answer
    Stephen Kitt
    2019-04-09T23:17:53+08:002019-04-09T23:17:53+08:00

    但是,为什么它在找到预期版本之前不做同样的事情,而不是接受库的第一个实例而不管其版本如何?

    确实如此,据它所知。zlib.so.1.2.7并且zlib.so.1.2.8两者都有一个 soname zlib.so.1,所以你alpha和bravo二进制文件说他们需要zlib.so.1。动态加载器加载它找到的第一个匹配库;它不知道版本 1.2.8 提供了bravo需要的附加符号。(这就是为什么发行版会煞费苦心地指定额外的依赖信息,例如zlib1g (>= 1.2.8)for bravo。)

    您可能认为这应该很容易解决,但事实并非如此,尤其是因为二进制文件和库将它们需要的符号与它们需要的库分开列出,因此加载器无法检查给定库是否提供了所有符号需要它。可以以多种方式提供符号,并且在符号和提供它们的库之间引入链接可能会破坏现有的二进制文件。符号插入还增加了乐趣,使事情复杂化(并使对安全敏感的开发人员大发雷霆)。

    一些库提供最终存储在 中的版本信息.gnu.version_r,并带有指向提供库的链接,这在这里会有所帮助,但libz不是其中之一。

    (鉴于 sonames,我希望您的alpha二进制文件可以正常工作zlib.so.1.2.8。)

    • 28

相关问题

  • `file` 报告的解释器指的是什么?

  • 为什么 .pc 文件没有在一个地方列出

  • 共享库次要版本管理

  • perl-Net-IP 包与 Net-IP 包相同吗?

  • Parabola (Arch-like) - ICU 更新导致某些程序需要两个不同版本的 ICU 库。两者都无法启动。无法复制

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve