一尘不染

应用程序在运行时如何解析为共享库的不同版本?

linux

我对共享库在Linux上的工作方式不了解。我试图了解应用程序如何在Linux上运行时解析同一共享库的不同修订版。

据我了解,共享库具有三个“名称”,例如,

  1. libmy.so.1.2(实名,即实际的obj文件)
  2. libmy.so.1(SONAME,嵌入在实际的obj文件中)
  3. libmy.so(链接器名称,在链接时提供给链接器,并嵌入在可执行文件中)

通过LDCONFIG安装库时,它将创建以下符号链接

  • (2)=>(1)
  • (3)=>(2)

现在让我们说我用以下实名libmy.so.2.0编译同一库的另一个版本。根据指南,SONAME将为libmy.so.2.0

在应用程序链接时,我将使用“ -l”标志提供的链接器名称是什么。遵循我阅读的指南(http://www.dwheeler.com/program-
library/Program-Library-HOWTO/x36.htm
l),它不是必须是libmy.so,如果是的话,两个版本的版本如何obj文件的区别?


阅读 254

收藏
2020-06-02

共1个答案

一尘不染

共享库的版本控制如下:

创建共享库时,请给它一个真实名称和一个soname。这些用于安装共享库(创建共享库和指向共享库的链接)。

因此,您可能会遇到以下情况:

pax> ls -al xyz*
-rw-r--r--  1 pax paxgroup    12345 Nov 18  2009 xyz.so.1.5
lrwxrwxrwx  1 pax paxgroup        0 Nov 18  2009 xyz.so.1 -> xyz.so.1.5
lrwxrwxrwx  1 pax paxgroup        0 Nov 18  2009 xyz.so -> xyz.so.1

xyz.so.1.5拥有的SONAMExyz.so.1

当连接环节xyz.so,它遵循的链接一路xyz.so.1.5和使用其SONAMExyz.so.1存储的可执行文件。然后,当您 运行
该可执行文件时,它会尝试加载xyz.so.1指向某个特定文件xyz.so.1.N(不一定是1.5版)的文件。

因此,您可以安装xyz.so.1.6和更新xyz.so.1链接以指向该链接,而已经链接的可执行文件将使用该链接。

这种多层方法的一个优点是,您可以拥有多个同名(xyz.so.1.*xyz.so.2.*)的潜在不兼容库,但是在每个主要版本中,
由于它们应该兼容 ,因此可以自由升级它们。

链接新的可执行文件时:

  • 与之链接的人xyz.so将获得最新主要版本的最新次要版本。
  • 与之链接的其他人xyz.so.1将获得特定主要版本的最新次要版本。
  • 还有其他链接xyz.so.1.2将获得特定主要版本的特定次要版本。

现在,当我们检查您的评论时,请记住最后一段:

现在让我们说我用以下实名编译同一库的另一个版本libmy.so.2.0。根据指南,SONAME为libmy.so.2.0

不,我不相信。该soname会更可能是libmy.so.2这样,你可以做轻微的更新到2.x流并获得最新的行为。

2020-06-02