Linux中的8个ldd命令示例

Ldd 是一个 Linux 命令行实用程序,用于在用户想知道可执行文件的共享库依赖关系甚至共享库的依赖关系的情况下使用。您可能已经注意到 Linux 机器的 /lib 和 /usr/lib 目录中有许多以 lib* 开头的文件。这些文件称为库。库是资源的集合,例如子例程/函数、类、值或类型规范。

库使程序可以使用通用例程,而无需维护其源代码的管理开销,或每次编译程序时编译它们的处理开销。

有两种类型的库:

静态库:不依赖外部库运行的完整程序的静态库。静态链接程序的特点是它们无需安装任何先决条件即可工作。静态库以*.a扩展结尾,这些库包含(单独的副本)到需要其功能的程序中。

动态库:适用于小型程序的动态库,这些库以.so扩展名结尾,在许多程序运行时使用动态链接的另一个特点,它可以共享一个库的副本,而不是相同代码的多个副本占用内存。所以最近的程序使用动态链接。在本文中,我们将介绍ldd用于管理共享库的命令。

共享库

当我们编写程序时,我们需要许多其他人已经编写的代码来为我们执行例行或专门的功能。这些代码片段存储在共享库中。为了使用它们,我们将它们与我们的代码链接起来,无论是在我们构建程序时还是在运行程序时。

LDD 命令语法和选项

ldd 命令打印共享对象依赖关系。该命令的语法是:

ldd [OPTION]... FILE...

我们可以使用 ldd 命令开关,这些开关可以插入到
上述命令中的 [OPTION] 位置:

  • -v :打印所有信息。
  • -d :处理数据重定位。
  • -r :处理数据和函数重定位。
  • -u :打印未使用的直接依赖项。

在执行命令之前,请记下以下几点:

- 文件 ld-linux.so 是动态链接器或加载器,它检查所请求程序的所需链接或库缓存并加载它。

- 缓存文件 /etc/ld.so.cache 包含在 /etc/ld.so.conf 中指定的目录中找到的库列表。这有助于提供更快的动态链接。

- 文件 /etc/ld.so.conf 指定搜索库的目录

1) 显示命令的依赖关系

我们将显示cp 命令的依赖关系。

$ ldd /bin/cp

    Output:

    linux-vdso.so.1 =>  (0x00007fffaf3ff000)

    libselinux.so.1 => /lib64/libselinux.so.1 (0x0000003a06a00000)

    librt.so.1 => /lib64/librt.so.1 (0x0000003a06200000)

    libacl.so.1 => /lib64/libacl.so.1 (0x0000003a13000000)

    libattr.so.1 => /lib64/libattr.so.1 (0x0000003a0ea00000)

    libc.so.6 => /lib64/libc.so.6 (0x0000003a05200000)

    libdl.so.2 => /lib64/libdl.so.2 (0x0000003a05a00000)

    /lib64/ld-linux-x86-64.so.2 (0x0000003a04a00000)

    libpthread.so.0 => /lib64/libpthread.so.0 (0x0000003a05600000)

2) 显示命令的依赖关系及详细信息

我们将cp使用-v选项显示命令的依赖关系以及更多详细信息。

$ ldd -v /bin/cp

    Output:

     linux-vdso.so.1 =>  (0x00007fff473ff000)

        libselinux.so.1 => /lib64/libselinux.so.1 (0x0000003a06a00000)

        librt.so.1 => /lib64/librt.so.1 (0x0000003a06200000)

        libacl.so.1 => /lib64/libacl.so.1 (0x0000003a13000000)

        libattr.so.1 => /lib64/libattr.so.1 (0x0000003a0ea00000)

        libc.so.6 => /lib64/libc.so.6 (0x0000003a05200000)

        libdl.so.2 => /lib64/libdl.so.2 (0x0000003a05a00000)

        /lib64/ld-linux-x86-64.so.2 (0x0000003a04a00000)

        libpthread.so.0 => /lib64/libpthread.so.0 (0x0000003a05600000)

        Version information:

        /bin/cp:

                librt.so.1 (GLIBC_2.2.5) => /lib64/librt.so.1

                libattr.so.1 (ATTR_1.1) => /lib64/libattr.so.1

                libacl.so.1 (ACL_1.2) => /lib64/libacl.so.1

                libacl.so.1 (ACL_1.0) => /lib64/libacl.so.1

                libc.so.6 (GLIBC_2.6) => /lib64/libc.so.6

                libc.so.6 (GLIBC_2.4) => /lib64/libc.so.6

                libc.so.6 (GLIBC_2.3) => /lib64/libc.so.6

                libc.so.6 (GLIBC_2.3.4) => /lib64/libc.so.6

                libc.so.6 (GLIBC_2.2.5) => /lib64/libc.so.6

        /lib64/libselinux.so.1:

                libdl.so.2 (GLIBC_2.2.5) => /lib64/libdl.so.2

                ld-linux-x86-64.so.2 (GLIBC_2.3) => /lib64/ld-linux-x86-64.so.2

                libc.so.6 (GLIBC_2.4) => /lib64/libc.so.6

                libc.so.6 (GLIBC_2.8) => /lib64/libc.so.6

                libc.so.6 (GLIBC_2.3) => /lib64/libc.so.6

                libc.so.6 (GLIBC_2.3.4) => /lib64/libc.so.6

                libc.so.6 (GLIBC_2.2.5) => /lib64/libc.so.6

        /lib64/librt.so.1:

                libpthread.so.0 (GLIBC_2.2.5) => /lib64/libpthread.so.0

                libpthread.so.0 (GLIBC_PRIVATE) => /lib64/libpthread.so.0

                libc.so.6 (GLIBC_2.3.2) => /lib64/libc.so.6

                libc.so.6 (GLIBC_2.2.5) => /lib64/libc.so.6

                libc.so.6 (GLIBC_PRIVATE) => /lib64/libc.so.6

        /lib64/libacl.so.1:

                libattr.so.1 (ATTR_1.0) => /lib64/libattr.so.1

                libc.so.6 (GLIBC_2.4) => /lib64/libc.so.6

                libc.so.6 (GLIBC_2.3.4) => /lib64/libc.so.6

                libc.so.6 (GLIBC_2.2.5) => /lib64/libc.so.6

        /lib64/libattr.so.1:

                libc.so.6 (GLIBC_2.4) => /lib64/libc.so.6

                libc.so.6 (GLIBC_2.2.5) => /lib64/libc.so.6

        /lib64/libc.so.6:

                ld-linux-x86-64.so.2 (GLIBC_PRIVATE) => /lib64/ld-linux-x86-64.so.2

                ld-linux-x86-64.so.2 (GLIBC_2.3) => /lib64/ld-linux-x86-64.so.2

        /lib64/libdl.so.2:

                ld-linux-x86-64.so.2 (GLIBC_PRIVATE) => /lib64/ld-linux-x86-64.so.2

                libc.so.6 (GLIBC_PRIVATE) => /lib64/libc.so.6

                libc.so.6 (GLIBC_2.2.5) => /lib64/libc.so.6

        /lib64/libpthread.so.0:

                ld-linux-x86-64.so.2 (GLIBC_2.3) => /lib64/ld-linux-x86-64.so.2

                ld-linux-x86-64.so.2 (GLIBC_2.2.5) => /lib64/ld-linux-x86-64.so.2

                ld-linux-x86-64.so.2 (GLIBC_PRIVATE) => /lib64/ld-linux-x86-64.so.2

                libc.so.6 (GLIBC_2.3.2) => /lib64/libc.so.6

                libc.so.6 (GLIBC_PRIVATE) => /lib64/libc.so.6

                libc.so.6 (GLIBC_2.2.5) => /lib64/libc.so.6

3) 显示命令未使用的直接依赖关系

我们可以使用选项显示cp命令的未使用的直接依赖关系。-u

$ ldd -u /bin/cp

    Output:

     Unused direct dependencies:

        /lib64/libselinux.so.1

        /lib64/librt.so.1

        /lib64/libacl.so.1

        /lib64/libattr.so.1

4) 显示 ldd 仅适用于动态可执行文件

我们将ldd仅使用-r选项显示动态可执行文件上的作品。

$  ldd -r /smart/pycharm-community-2017.3.3/bin/pycharm.sh

    Output:

     not a dynamic executable

输出显示提供的文件不是动态可执行文件的明确消息状态。

5) 带有标准命令行可执行文件的 ldd

当我们尝试ldd使用标准命令行可执行文件ls时,我们需要动态可执行文件的完整路径。

$ ldd ls

    Output:

    ldd: ./ls: No such file or directory

我们看到它ldd表示它无法找到ls

$ ldd /bin/ls

    Output:

    linux-vdso.so.1 =>  (0x00007fff5cbea000)

    libselinux.so.1 => /lib64/libselinux.so.1 (0x0000003a06a00000)

    librt.so.1 => /lib64/librt.so.1 (0x0000003a06200000)

    libcap.so.2 => /lib64/libcap.so.2 (0x0000003a07600000)

    libacl.so.1 => /lib64/libacl.so.1 (0x0000003a13000000)

    libc.so.6 => /lib64/libc.so.6 (0x0000003a05200000)

    libdl.so.2 => /lib64/libdl.so.2 (0x0000003a05a00000)

    /lib64/ld-linux-x86-64.so.2 (0x0000003a04a00000)

    libpthread.so.0 => /lib64/libpthread.so.0 (0x0000003a05600000)

    libattr.so.1 => /lib64/libattr.so.1 (0x0000003a0ea00000)

但是使用绝对路径,ldd效果很好。

6) 知道给定的可执行守护进程支持 TCP Wrapper

要确定给定的可执行守护程序是否支持 TCP Wrapper,请运行以下命令。

$ sudo ldd /usr/sbin/sshd | grep libwrap

    Output:

    libwrap.so.0 => /lib64/libwrap.so.0 (0x00007f1cc2ac6000)

输出表明 OpenSSH (sshd) 守护程序支持 TCP Wrapper。

7) ldd 缺少依赖项

ldd当可执行文件由于缺少依赖项而失败时,我们可以使用该命令。一旦我们发现缺少的依赖项,我们可以安装它或使用ldconfig命令更新缓存。

$ sudo ldd /bin/mv

libacl.so.1 => /lib/libacl.so.1 (0×40016000)

libc.so.6 => /lib/libc.so.6 (0x4001c000)

libattr.so.1 => /lib/libattr.so.1 (0×40141000)

/lib/ld-linux.so.2 => /lib/ld-linux.so.2 (0×40000000)

我们将通过键入以下命令执行重定位并报告任何丢失的对象(仅限 ELF)。

$ sudo ldd -d path/to/executable_file

我们将为数据对象和函数执行重定位,并通过键入以下命令报告任何丢失的对象或函数(仅限 ELF)。

$ sudo ldd -r path/to/executable_file

常见的共享库相关错误

1) 缺少库错误

即使提到的库在新的安装路径“/opt/newinstall/lib”中可用,您也可能会遇到缺少库错误。这是因为系统不知道这个目录来检查库。这可以通过两种方式中的任何一种来解决。

一个。执行以下命令,

$ ldconfig -n /opt/newinstall/lib

湾。您可以在 /etc/ld.so.conf 文件中看到以下包含行:

包括 ld.so.conf.d/*.conf

因此,在 /etc/ld.so.sonf.d 文件夹中创建一个文件,说 newinstall.conf 具有以下内容。

/opt/newinstall/lib

然后,执行:

$ ldconfig

2) 动态链接器错误,无法映射缓存文件

这可能是由于缓存文件损坏。这可以通过使用 ldconfig 重建缓存文件来解决。

$ ldconfig

ldconfig 命令

ldconfig 创建必要的链接和缓存(供运行时链接器 ld.so 使用)到在命令行指定的目录、文件 /etc/ld.so.conf 中找到的最新共享库,以及在受信任的目录(/usr/lib 和 /lib)中。

举些例子:

执行以下命令为共享二进制文件设置正确的链接并重建缓存。

$ ldconfig –v

安装新的共享库后执行以下命令将正确更新/lib中的共享库符号链接。

$ ldconfig -n /lib

以下命令将打印当前缓存。

$ ldconfig -p

结论

在本教程中,我们学习了如何使用 ldd 命令以及如何在 linux 命令行中使用。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 你可以使用 `ldd` 命令来查看一个 Linux 程序需要调用哪些共享库。这个命令会列出程序依赖的动态链接库的路径。 具体来说,可以在终端输入以下命令: ``` ldd /path/to/your/program ``` 其,`/path/to/your/program` 是你要查看的程序的路径。该命令会输出程序依赖的动态链接库的路径列表,如: ``` linux-vdso.so.1 => (0x00007ffd43756000) libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f708d7a5000) libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007f708d49c000) libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f708d0d6000) /lib64/ld-linux-x86-64.so.2 (0x00007f708d9dd000) ``` 其每一行包含库的路径和在程序的地址。需要调用的库路径通常以 `lib` 开头。例如,上面的输出程序需要调用 `libpthread.so.0`,`libm.so.6` 和 `libc.so.6` 这三个库。 ### 回答2: 要查看一个Linux程序需要调用哪些库,可以使用以下几种方法: 1. 使用ldd命令ldd命令可以列出一个可执行文件所依赖的共享库。在终端输入ldd加上程序的路径,如:ldd /path/to/program。系统会输出该程序所依赖的共享库列表。 2. 使用readelf命令:readelf命令是GNU Binutils软件包的工具之一,可用于查看可执行文件的结构信息。在终端输入readelf加上程序的路径,如:readelf -d /path/to/program。系统会输出该程序的动态结构信息,包括所依赖的共享库。 3. 使用objdump命令:objdump命令也是Binutils软件包的工具之一,可以对可执行文件进行反汇编。在终端输入objdump加上程序的路径,如:objdump -p /path/to/program。系统会输出该程序的段头信息,包括所依赖的共享库。 通过以上方法,我们可以查看一个Linux程序需要调用哪些库。这对于程序的开发、调试和部署都非常重要,可以帮助我们确保所需的库已经安装,并能够正确地加载和运行程序。 ### 回答3: 在Linux系统,可以使用ldd命令来查看一个程序需要调用哪些库。 使用方法如下: 1. 打开终端窗口,在命令输入ldd,然后在空格后加上待查询程序的路径,按下回车键。 示例ldd /usr/bin/gcc 这将显示出gcc程序所需要调用的所有库文件。 2. 当执行ldd命令后,终端会输出一段关于这个程序的动态链接库(也称为共享库)的信息。每行的开头是共享库的路径,紧随其后是共享库的路径的匹配类型。 示例:/lib64/ld-linux-x86-64.so.2 (0x7f7abffff000) 这是程序所依赖的动态链接器库,用于加载和链接其他共享库。 示例:libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x7f7ac01bf000) 这是程序所依赖的线程库,用于支持多线程编程。 示例:libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x7f7abf0a0000) 这是程序所依赖的数学库,用于进行数学计算。 3. 通过不断查看终端输出的信息,你可以了解到程序所需要调用的所有库文件。 需要注意的是,如果某个库文件不存在或者不可访问,ldd命令将会输出"not found"的提示信息。如果某个库文件无法找到,可能会导致程序无法正常运行。 通过使用ldd命令,我们可以方便地查看一个Linux程序需要调用哪些库,这对于排查程序依赖问题和解决运行时错误非常有帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

太极淘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值