Kyl*_*S-C 3 linker shared-libraries elf
给定一个 ELF 二进制文件或共享对象,我如何才能最轻松地查看所需共享库的加载顺序?
它们是否按照列出的顺序加载readelf -d?
我怎样才能最容易地看到所需共享库的加载顺序?
使用LD_DEBUG:
LD_DEBUG=files /bin/ls
13444:
13444: file=libc.so.6 [0]; needed by who [0]
...
13444: file=libnss_files.so.2 [0]; needed by who [0]
...
Run Code Online (Sandbox Code Playgroud)
欲了解更多信息,请参阅 ld.so。
它们是否按照 readelf -d 列出的顺序加载?
不一定,例如它会受到预加载的影响(LD_PRELOAD,/etc/ld.so.preload)。
使用LD_DEBUG=files允许您查看搜索库的顺序以及它们初始化的顺序。后者可能与前者不同。
它们是否按照列出的顺序加载
readelf -d
取决于你所说的“加载”是什么意思。一旦初始化程序返回,库就被“完全加载”。
NEEDED根据该定义,不:列出的依赖项顺序readelf -d和加载顺序不同。
考虑a.out哪个取决于libA.so和libB.so:
readelf -d a.out | grep NEEDED
0x0000000000000001 (NEEDED) Shared library: [libA.so]
0x0000000000000001 (NEEDED) Shared library: [libB.so]
0x0000000000000001 (NEEDED) Shared library: [libc.so.6]
Run Code Online (Sandbox Code Playgroud)
此外,libA.so它本身取决于libC.so和libD.so:
readelf -d libA.so | grep NEEDED
0x0000000000000001 (NEEDED) Shared library: [libC.so]
0x0000000000000001 (NEEDED) Shared library: [libD.so]
0x0000000000000001 (NEEDED) Shared library: [libc.so.6]
Run Code Online (Sandbox Code Playgroud)
搜索库的顺序:
LD_DEBUG=files ./a.out |& grep 'needed by'
49169: file=libA.so [0]; needed by ./a.out [0]
49169: file=libB.so [0]; needed by ./a.out [0]
49169: file=libc.so.6 [0]; needed by ./a.out [0]
49169: file=libC.so [0]; needed by ./libA.so [0]
49169: file=libD.so [0]; needed by ./libA.so [0]
Run Code Online (Sandbox Code Playgroud)
库“完全加载”的顺序:
LD_DEBUG=files ./a.out |& grep 'calling init'
69038: calling init: /lib/x86_64-linux-gnu/libc.so.6
69038: calling init: ./libD.so
69038: calling init: ./libC.so
69038: calling init: ./libB.so
69038: calling init: ./libA.so
Run Code Online (Sandbox Code Playgroud)
其他可能影响加载顺序的因素:
LD_PRELOAD或者/etc/ld.so.preload。dlopen在其初始化程序中执行。