glibc.so.6 中的“6”是什么意思?

glibc.so.6 中的“6”是什么意思?

在探索 C++ 二进制文件时,我发现libstdc++.so.6dyn 链接到libm.so.6libc.so.6

$ ldd /lib/x86_64-linux-gnu/libstdc++.so.6 
        linux-vdso.so.1 (0x00007ffcb737b000)
        libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007fd3b2295000)
        libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fd3b1c00000)
        /lib64/ld-linux-x86-64.so.2 (0x00007fd3b2396000)
        libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007fd3b2275000)

我的问题是:

  1. 6名字里的意思是什么?本来以为是glibc的版本,结果版本是2.35,与6.

    $ strings /lib/x86_64-linux-gnu/libc.so.6  | grep GLIBC_2.3
    GLIBC_2.3
    ...
    GLIBC_2.35
    
  2. 这个后缀为何6如此受欢迎?

  3. libc.so.7有什么时候发布的时间表吗?

答案1

使用 6 后缀是出于历史原因,详细信息请参见man libc在 Linux 上。本质上,Linux 上使用了 GNU C 库的一个分支;此次发布了主要版本 2 到 5。版本 5 使用 ELF 并以共享库 soname 发布libc.so.5。当 GNU C 库的版本 2 在 Linux 上发布时,它使用共享库 sonamelibc.so.6以避免与早期库混淆。

相关库使用相同的后缀。有些架构使用稍微不同的后缀;例如,Alpha 和 Itanium 上的 GNU C 库是libc.so.6.1.

GNU C 库具有强大的向后兼容性历史,并使用许多不同的机制来支持引入重大更改,而不会破坏旧的二进制文件(包括版本化符号)。仅当绝对需要无法缓解的重大更改时才会使用新的 soname ( libc.so.7),因此我们不太可能很快看到这样的更改。

答案2

这是 ABI(应用程序二进制接口) 版本。

它仅在进行重大更改时才会增加,现在强烈避免这样做libc,因此大多数发行版已经运行了libc.so.6一段时间。

一般来说,它允许系统上同时存在一个库的多个不兼容版本,支持为不同版本构建的不同应用程序。

例如,Ubuntu 18.04 提供了libcurl.so.3(通过 package libcurl3)和libcurl.so.4(通过 package libcurl4),两者都是从 cURL 版本 7.58.0 构建的。

相关内容