Strace - Strace

strace
Strace logo.svg
Původní autořiPaul Kranenburg
VývojářiDmitrij Levin
Stabilní uvolnění
5.9[1] / 24. září 2020; Před 60 dny (2020-09-24)
Úložiště Upravte to na Wikidata
NapsánoC[2]
Operační systémLinux
PlošinaAArch64, DEC Alpha, OBLOUK, ARM EABI / OABI, AVR32, Blackfin, C-SKY, HP PA-RISC, IA-32, IA-64, Motorola 68k, Představivost META, MicroBlaze, MIPS, Nios II, OpenRISC, Napájení ISA 32/64 bitů, RISC-V, Systém / 390 /z / Architektura, SuperH 32/64 bitů, SPARC 32/64 bitů, DLAŽDICE, TILEPro, TILE-Gx, x86-64, x32 ABI, Xtensa
K dispozici vAngličtina
TypLadění
LicenceLGPL v2.1 +
webová stránkastrace.io

strace je diagnostický, ladění a instruktážní uživatelský prostor nástroj pro Linux. Používá se ke sledování a manipulaci s interakcemi mezi procesy a Linuxové jádro, který zahrnuje systémová volání, signál dodávky a změny stavu procesu. Fungování sledování je umožněno funkcí jádra známou jako ptrace.

Nějaký Unixový systémy poskytují další diagnostické nástroje podobné strace, jako např krov.

Dějiny

Strace byl původně napsán pro SunOS autor Paul Kranenburg v roce 1991, podle oznámení o autorských právech, a publikováno počátkem roku 1992 ve třetím svazku souboru comp.sources.sun. Počáteční PŘEČTĚTE SI soubor obsahoval následující:[3]

strace (1) je sledovač systémových volání pro systémy Sun (tm) podobně jako program dodávaný společností Sun stopa (1). strace (1) je užitečný nástroj pro třídění ladicích programů, pro které není k dispozici žádný zdroj, který bohužel zahrnuje téměř veškerý systémový software dodávaný společností Sun.

Později Branko Lankester přenesl tuto verzi na Linux, vydal svou verzi v listopadu 1992 a druhé vydání následovalo v roce 1993.[4][5] Richard Sladkey spojil tyto samostatné verze strace v roce 1993 a přenesl program na SVR4 a Solaris v roce 1994,[6] což má za následek trasování 3.0, které bylo oznámeno v comp.sources.misc v polovině roku 1994.[7]

Počínaje rokem 1996 udržoval strace Wichert Akkerman. Během jeho funkčního období se vývoj strace přesunul do CVS; porty do FreeBSD a mnoho architektur na Linuxu (včetně ARM, IA-64, MIPS, PA-RISC, PowerPC, s390, SPARC). V roce 2002 bylo břemeno udržování strace přeneseno na Rolanda McGratha. Od té doby Strace získal podporu pro několik nových linuxových architektur (AMD64, s390x, SuperH), podporu bi-architektury pro některé z nich a obdržel řadu dodatků a vylepšení v dekodérech syscalls na Linuxu; vývoj strace migroval na sakra během tohoto období. Od roku 2009 je strace aktivně udržována Dmitrijem Levinem. strace od té doby získal podporu pro architektury AArch64, ARC, AVR32, Blackfin, Meta, Nios II, OpenSISC 1000, RISC-V, Tile / TileGx, Xtensa.

Poslední verze strace, která měla nějaké (evidentně mrtvé)[8] kód pro ne-Linux operační systémy 4.6, vydané v březnu 2011.[9] Ve stopové verzi 4.7, vydané v květnu 2012,[10] veškerý jiný než linuxový kód byl odstraněn;[11] od strace 4.13,[12] projekt se řídí plánem vydání linuxového jádra as verzí 5.0,[13] následuje také schéma verzí Linuxu.

V roce 2012 strace také získal podporu pro trasování cesty a dekódování cesty deskriptoru souboru.[14] V srpnu 2014 bylo vydáno strace 4.9[15][16], kde byla přidána podpora pro tisk trasování zásobníku. V prosinci 2016[17][18], syscall vstřikování poruch funkce byla implementována.

Historie verzí

VerzeDatum vydání
5.924. září 2020[19]
5.86. srpna 2020[20]
5.71. června 2020[21]
5.67. dubna 2020[22]
5.56. února 2020[23]
5.428. listopadu 2019[24]
5.325. září 2019[25]
5.212. července 2019[26]
5.122. května 2019[27]
5.019. března 2019[28]
4.2626. prosince 2018[29]
4.2530. října 2018[30]
4.2414. srpna 2018[31]
4.2314. června 2018[32]
4.225. dubna 2018[33]
4.2113. února 2018[34]
4.2013. listopadu 2017[35]
4.195. září 2017[36]
4.185. července 2017[37]
4.1724. května 2017[38]
4.1614. února 2017[39]
4.1514. prosince 2016[40]
4.144. října 2016[41]
4.1326. července 2016[42]
4.1231. května 2016[43]
4.1121. prosince 2015[44]
4.106. března 2015[45]
4.915. srpna 2014[46]
4.83. června 2013[47]
4.72. května 2012[48]
4.615. března 2011[49]
4.5.2013. dubna 2010
4.5.1921. října 2009
4.5.1828. srpna 2008
4.5.1721. července 2008
4.5.163. srpna 2007
4.5.1516. ledna 2007
4.5.1416. ledna 2007
4.5.133. srpna 2005
4.5.128. června 2005
4.5.1122. března 2005
4.5.1013. března 2005
4.5.94. února 2004
4.5.819. října 2004
4.5.731. srpna 2004
4.5.612. července 2004
4.5.527. června 2004
4.5.43. června 2004
4.5.316. dubna 2004
4.5.21. března 2004
4.5.113. listopadu 2003
4.524. září 2003
4.419. srpna 2001
4.3.17. dubna 2001
4.31. dubna 2001
4.221. ledna 2000
4.126. listopadu 1999
4.0.125. července 1999
4.09. července 1999
3.99.19. června 1999
3.9927.dubna 1999
3.11. června 1996
3.09. července 1994[50]

Použití a funkce

Nejběžnějším použitím je spuštění programu pomocí trasování, které vytiskne seznam systémových volání provedených programem. To je užitečné, pokud program neustále havaruje nebo se nechová podle očekávání; například použití trasování může odhalit, že se program pokouší získat přístup k souboru, který neexistuje nebo jej nelze přečíst.

Alternativní aplikací je použití -p příznak pro připojení k běžícímu procesu. To je užitečné, pokud proces přestal reagovat a mohl by například odhalit, že proces blokuje při pokusu o připojení k síti.

Mimo jiné funkce strace umožňuje následující:

  • Specifikování filtru názvů syscall, které by měly být sledovány (přes -e stopa = možnost): podle jména, jako klon, vidlice, vfork; pomocí jedné z předdefinovaných skupin, jako % ipc nebo %soubor; nebo (od verze 4.17) pomocí syntaxe regulárního výrazu, jako -e trace = / hodiny _. *.
  • Zadání seznamu tras, které mají být sledovány (-P /etc/ld.so.cache, například).
  • Zadání seznamu deskriptorů souborů, jejichž I / O by měl být vypsán (-e číst = a -e napsat = možnosti).
  • Počítání času a počtu spuštění syscall (-T, -C, -C, a -w možnosti).
  • Tisk relativních nebo absolutních časových razítek (-t a -r možnosti).
  • Úprava návratového a chybového kódu zadaných syscallů a vkládání signálů po jejich provedení (od verze 4.15, -e vložit = volba).
  • Extrahování informací o deskriptorech souborů (včetně soketů, -y volba).
  • Tisk trasování zásobníku, včetně (od streamu 4.21) demanglingu symbolu (-k volba).
  • Filtrování podle návratového stavu syscall (-e status = volba; od strace 5.2[51]).

strace podporuje dekódování argumentů některých tříd ioctl příkazy, jako např BTRFS_ *, V4L2_ *, DM_ *, NSFS_ *, MEM *, EVIO *, KVM_ * a několik dalších.

Protože trasování podrobně popisuje systémová volání, nelze jej použít k detekci tolika problémů jako ladicí program kódu, jako je GNU Debugger (gdb). Používá se však snadněji než debugger kódu a je velmi užitečným nástrojem pro správce systému. Používají ji také vědci k vygenerování trasování systémových volání na později přehrání systémového volání.[52][53][54]

Příklady

Následuje příklad typického výstupu souboru strace příkaz:

uživatel @ server: ~ $ strace ls...open (".", O_RDONLY | O_NONBLOCK | O_LARGEFILE | O_DIRECTORY | O_CLOEXEC) = 3fstat64 (3, {st_mode = S_IFDIR | 0755, st_size = 4096, ...}) = 0fcntl64 (3, F_GETFD) = 0x1 (příznaky FD_CLOEXEC)getdents64 (3, / * 18 záznamů * /, 4096) = 496getdents64 (3, / * 0 záznamů * /, 4096) = 0zavřít (3) = 0fstat64 (1, {st_mode = S_IFIFO | 0600, st_size = 0, ...}) = 0mmap2 (NULL, 4096, PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANONYMOUS, -1, 0) = 0xb7f2c000write (1, "autofsbackupscacheflexlmgames" ..., 86autofsA

Výše uvedený fragment je pouze malou částí výstupu strace při spuštění naje 'příkaz. Ukazuje, že aktuální pracovní adresář je otevřen, zkontrolován a načten jeho obsah. Výsledný seznam názvů souborů se zapíše na standardní výstup.

Podobné nástroje

Různé operační systémy mají jiné podobné nebo související instrumentace nástroje nabízející podobné nebo pokročilejší funkce; některé z nástrojů (i když používají stejný nebo podobný název) mohou používat zcela odlišné pracovní mechanismy, což vede k různým sadám funkcí nebo výsledkům. Mezi tyto nástroje patří:

Viz také

Reference

  1. ^ „uvolněno trasování 5.9“ (Poštovní seznam). 2020-09-24. Citováno 2020-09-24.
  2. ^ https://openhub.net/p/strace
  3. ^ Paul Kranenburg (2. března 1992). „Strace - alternativní sledovač syscall“. Diskusní skupinacomp.sources.sun.
  4. ^ Branko Lankester (5. listopadu 1992). "první linuxové vydání strace".
  5. ^ Branko Lankester (18. června 1993). "druhé linuxové vydání strace".
  6. ^ "strace". manned.org. 21. června 1994.
  7. ^ „Index SUNET /pub/usenet/ftp.uu.net/comp.sources.misc/volume43/strace“. Citováno 14. ledna 2015.
  8. ^ Denys Vlasenko (7. února 2012). „Co takhle odstranit jiný než linuxový kód?“.
  9. ^ Dmitrij V. Levin (16. března 2011). "uvolnění 4.6 verze".
  10. ^ Dmitrij V. Levin (2. května 2012). "uvolněno 4.7".
  11. ^ Dmitrij V. Levin (20. dubna 2012). „Pozoruhodné změny ve verzi 4.7“.
  12. ^ Dmitrij V. Levin (4. října 2016). "uvolnění verze 4.14".
  13. ^ Dmitrij V. Levin (19. března 2019). "uvolnění verze 5.0".
  14. ^ Dmitrij V. Levin (1. května 2012). „Pozoruhodné změny ve verzi 4.7“.
  15. ^ Dmitrij V. Levin (15. srpna 2014). „uvolnění 4.9 verze“.
  16. ^ Dmitrij V. Levin (15. srpna 2014). „Pozoruhodné změny ve verzi 4.9“.
  17. ^ Dmitrij V. Levin (14. prosince 2016). „uvolněno trasování 4.15“.
  18. ^ Dmitrij V. Levin (14. prosince 2016). „Pozoruhodné změny ve verzi 4.15“.
  19. ^ Dmitrij V. Levin (2020-09-24). „uvolněno trasování 5.9“.
  20. ^ Dmitrij V. Levin (06.08.2020). „uvolněno trasování 5.8“.
  21. ^ Dmitrij V. Levin (01.06.2020). „uvolněno strace 5.7“.
  22. ^ Dmitrij V. Levin (07.04.2020). "uvolnění strace 5.6".
  23. ^ Dmitrij V. Levin (06.02.2020). "uvolnění strace 5.5".
  24. ^ Dmitrij V. Levin (2019-11-28). „uvolnění strace 5.4“.
  25. ^ Dmitrij V. Levin (2019-09-25). „uvolnění strace 5.3“.
  26. ^ Dmitrij V. Levin (12.7.2019). "uvolnění strace 5.2".
  27. ^ Dmitrij V. Levin (2019-05-22). "uvolnění strace 5.1".
  28. ^ Dmitrij V. Levin (2019-03-19). "uvolnění verze 5.0".
  29. ^ Dmitrij V. Levin (26. 12. 2018). "uvolnění verze 4.26".
  30. ^ Dmitrij V. Levin (2018-10-30). "uvolnění 4.25 uvolněno".
  31. ^ Dmitrij V. Levin (2018-08-14). "uvolnění 4.24 verze".
  32. ^ Dmitrij V. Levin (14.06.2018). "uvolnění 4.23 verze".
  33. ^ Dmitrij V. Levin (05.04.2018). "uvolnění streamu 4.22".
  34. ^ Dmitrij V. Levin (2018-02-13). "uvolnění 4.21 verze".
  35. ^ Dmitrij V. Levin (13. 11. 2017). "uvolnění 4.20 verze".
  36. ^ Dmitrij V. Levin (05.09.2017). „uvolněno trasování 4.19“.
  37. ^ Dmitrij V. Levin (05.07.2017). „uvolněno trasování 4.18“.
  38. ^ Dmitrij V. Levin (2017-05-24). "uvolnění verze 4.17".
  39. ^ Dmitrij V. Levin (2017-02-14). "uvolnění verze 4.16".
  40. ^ Dmitrij V. Levin (2016-12-14). „uvolněno trasování 4.15“.
  41. ^ Dmitrij V. Levin (04.10.2016). "uvolnění verze 4.14".
  42. ^ Dmitrij V. Levin (2016-07-26). „uvolněno trasování 4.13“.
  43. ^ Dmitrij V. Levin (2016-05-31). "uvolnění verze 4.12".
  44. ^ Dmitrij V. Levin (2015-12-21). „uvolnění trasování 4.11“.
  45. ^ Dmitrij V. Levin (06.03.2015). „uvolněno trasování 4.10“.
  46. ^ Dmitrij V. Levin (15. 8. 2014). „uvolnění 4.9 verze“.
  47. ^ Dmitrij V. Levin (06.06.2013). "uvolnění strace 4.8".
  48. ^ Dmitrij V. Levin (2012-05-02). "uvolněno 4.7".
  49. ^ Dmitrij V. Levin (2011-03-15). "uvolnění 4.6 verze".
  50. ^ Rick Sladkey (09.07.1994). "v43i075: strace - sledovač systémových volání pro Sunos, Linux, SVR4, Solaris2, Part01 / 10".
  51. ^ Je to zkratka pro zobrazování pouze úspěšných hovorů, -z Tato možnost byla původně přidána do trasování 4.5, ale nikdy nebyla zdokumentována, protože nefungovala správně.
  52. ^ Horky, Jiří (2013). „Ioapps IO profiler a IO traces replayer“. Citováno 2013-09-16.
  53. ^ Waterland, Amos (2007). "Přehrávač systémových volání sreplay". Citováno 2013-09-16.
  54. ^ Burton, Ariel (1998). "Charakterizace pracovní zátěže pomocí odlehčeného trasování systémových volání a opětovného provedení" (PDF). Citováno 2013-09-16.
  55. ^ "XTrace - trasování připojení protokolu X". xtrace.alioth.debian.org. Citováno 2014-08-12.
  56. ^ „dtrace (1) Mac OS X Manual Page“. Developer.apple.com. Citováno 2014-07-23.
  57. ^ „IntellectualHeaven - Strace For Windows“. intelektuálníheaven.com. Citováno 29. ledna 2015.

externí odkazy