Czy określić bezpośrednie zależności obiektów współdzielonych pliku binarnego systemu Linux?

170

Jak mogę łatwo znaleźć bezpośrednie zależności między obiektami współdzielonymi pliku binarnego systemu Linux w formacie ELF?

Wiem o narzędziu ldd, ale wydaje się, że wypisuje wszystkie zależności pliku binarnego, w tym zależności wszelkich obiektów współdzielonych, od których zależy plik binarny.

Bezpłatne Wildebeest
źródło
2
powiązany unix.stackexchange.com/questions/120015/…
Ciro Santilli 郝海东 冠状 病 六四 事件 法轮功

Odpowiedzi:

262

Możesz użyć readelfdo eksploracji nagłówków ELF. readelf -dwyświetli bezpośrednie zależności jako NEEDEDsekcje.

 $ readelf -d elfbin

Dynamic section at offset 0xe30 contains 22 entries:
  Tag        Type                         Name/Value
 0x0000000000000001 (NEEDED)             Shared library: [libssl.so.1.0.0]
 0x0000000000000001 (NEEDED)             Shared library: [libc.so.6]
 0x000000000000000c (INIT)               0x400520
 0x000000000000000d (FINI)               0x400758
 ...
Mata
źródło
20
To jest świetne. W przeciwieństwie do ldd, readelf może sprawdzić plik binarny międzyplatformowy (tj. Sprawdzić plik wykonywalny ARM z systemu Linux x86-64).
Robert Calhoun
86

Jeśli chcesz znaleźć zależności rekurencyjnie (w tym zależności zależności, zależności zależności zależności itp.)…

Możesz użyć lddpolecenia. ldd - wyświetla zależności bibliotek współdzielonych

Serge C
źródło
5
Polecenie ldd sprawdza zależności zależności, czego nie chcę.
bezpłatny Wildebeest
11
U mnie to działa dobrze. Mówi nawet, które z bibliotek można było znaleźć, a które nie.
Philipp F,
2
ldd nie działałby z plikiem wykonywalnym - jest przydatny tylko do znalezienia zależności bibliotek współdzielonych.
Tuxdude
2
Tuxdude, dlaczego tak myślisz? Jaki jest powód braku użyteczności ldd dla plików wykonywalnych ELF?
Vitaly Isaev
Jest to niesamowite dla współdzielonych bibliotek współdzielonych, które wymagają kopiowania z maszyny programistycznej do archiwum wdrożeniowego.
Tomáš Zato - Przywróć Monikę
30

objdumpNarzędzie może wam tę informację. Jeśli powołać objdumpz -xopcji, aby zmusić go do wyjścia wszystkich nagłówków Pokochasz więc znaleźć wspólne zależności obiektów na samym początku, w sekcji „Dynamiczny”.

Na przykład uruchomienie objdump -x /usr/lib/libXpm.so.4w moim systemie daje następujące informacje w sekcji „Dynamiczna sekcja”:

Dynamic Section:
  NEEDED               libX11.so.6
  NEEDED               libc.so.6
  SONAME               libXpm.so.4
  INIT                 0x0000000000002450
  FINI                 0x000000000000e0e8
  GNU_HASH             0x00000000000001f0
  STRTAB               0x00000000000011a8
  SYMTAB               0x0000000000000470
  STRSZ                0x0000000000000813
  SYMENT               0x0000000000000018
  PLTGOT               0x000000000020ffe8
  PLTRELSZ             0x00000000000005e8
  PLTREL               0x0000000000000007
  JMPREL               0x0000000000001e68
  RELA                 0x0000000000001b38
  RELASZ               0x0000000000000330
  RELAENT              0x0000000000000018
  VERNEED              0x0000000000001ad8
  VERNEEDNUM           0x0000000000000001
  VERSYM               0x00000000000019bc
  RELACOUNT            0x000000000000001b

Bezpośrednie zależności obiektów współdzielonych są wymienione jako wartości „POTRZEBNE”. W powyższym przykładzie libXpm.so.4w moim systemie wystarczy libX11.so.6i libc.so.6.

Należy zauważyć, że nie oznacza to, że wszystkie symbole wymagane przez przekazywany plik binarny objdumpbędą obecne w bibliotekach, ale przynajmniej pokazuje, jakie biblioteki program ładujący będzie próbował załadować podczas ładowania pliku binarnego.

Bezpłatne Wildebeest
źródło
13

ldd -v wyświetla drzewo zależności w sekcji „Informacje o wersji:”. Pierwszy blok w tej sekcji to bezpośrednie zależności pliku binarnego.

Zobacz Hierarchical ldd (1)

Hannes
źródło
Jaka jest różnica między tym a objdump -x <binary> | grep "NEEDED"? To znaczy, oba są prawie dokładnie takie same, po prostu otrzymuję jeden .soplik więcej z lddniż objdump. Ale fakt, że wyniki nie są takie same, sprawia, że ​​zastanawiam się, która metoda jest dokładniejsza.
m4l490n