首页 > 解决方案 > 获取准确的 ELF 依赖项

问题描述

我知道两种查找依赖项的方法, ldd app.out它们会为一个简单的应用程序返回这个:

linux-vdso.so.1 (0x00007ffff93f5000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f02383a0000)
/lib64/ld-linux-x86-64.so.2 (0x00007f0238800000)

readelf -d app.out | grep NEEDED返回:

0x0000000000000001 (NEEDED)             Shared library: [libc.so.6]

我想了解为什么输出差异,libc.so在这两种情况下,/lib64/ld-linux-x86-64.so.2都是解释器并且在第一个中是有意义的,但是大约linux-vdso.so.1?哪个更准确?

标签: linuxprocesslinux-kernelelfldd

解决方案


readelf -d显示应用程序想要ldd什么,显示链接器想要什么。

它们是不同的,因为:

  • ldd显示依赖关系的传递闭包(即递归),而readelf仅显示直接依赖关系
  • ldd显示加载程序,它readelf考虑与动态依赖项分开
  • ldd显示虚拟库,这是应用程序不关心的系统实现细节

这意味着哪个更准确取决于您和您的用例。

如果您正在创建 VM 映像并需要复制所有依赖项,则可以使用它,ldd因为它决定了当前系统运行应用程序所需的内容。如果您正在编写类似 的兼容层wine,您会使用它,readelf因为它决定了应用程序需要从主机系统获得什么。


推荐阅读