Debugging (Русский)/Getting traces (Русский)
Эта статья описывает создание отладочного пакета и получение с его помощью отладочной информации, которую можно будет отправить разработчикам в сообщении об ошибке.
Обычно исполняемые файлы очищаются (strip) от человекочитаемого контекста, чтобы уменьшить их размер. Кроме того, расширенная отладочная информация обычно не добавляется в исполняемый файл, что сильно снижает качество трассировки. Поэтому перед получением трассировки нужно пересобрать пакет без выполнения strip и с отладочной информацией.
Используйте полную трассировку стека, чтобы сообщить разработчикам о найденной вами ошибке — это сильно поможет в решении проблемы.
Имена пакетов
Для начала нужно выяснить имена пакетов, которые требуется пересобрать.
Во время отладки, например, при просмотре дампа памяти в gdb, вы увидите что-то подобное:
[...] Backtrace was generated from '/usr/bin/epiphany' (no debugging symbols found) Using host libthread_db library "/lib/libthread_db.so.1". (no debugging symbols found) [Thread debugging using libthread_db enabled] [New Thread -1241265952 (LWP 12630)] (no debugging symbols found) 0xb7f25410 in __kernel_vsyscall () #0 0xb7f25410 in __kernel_vsyscall () #1 0xb741b45b in ?? () from /lib/libpthread.so.0 [...]
строки вида ??
и (no debugging symbols found)
показывают, что необходимая отладочная информация, такая, как названия функций, файлов, библиотек, отсутствует в отлаживаемом файле. Проверить, какому пакету принадлежит исполняемый файл или библиотека можно, например, с помощью pacman:
$ pacman -Qo /lib/libthread_db.so.1
/lib/libthread_db.so.1 is owned by ''glibc'' 2.5-8
Пакет версии 2.5-8. Следует составить список пакетов, которые необходимо заменить для отладки.
Есть несколько способов получения отладочной информации, каждый из которых описан в соответствующем разделе: #Debuginfod, #Установка отладочных пакетов, #Пересборка пакетов.
Debuginfod
Для некоторых пакетов из официальных репозиториев можно скачать отладочную информацию с помощью debuginfod.
Например, чтобы скачать отладочные символы для пакета вместе с исходным кодом, можно использовать debuginfo-find:
Некоторые отладчики, например gdb, умеют скачивать их автоматически.
Например, вы можете сделать:
# coredumpctl gdb
И затем в gdb
(gdb) bt full
и в вашей системе появятся отладочные символы для последнего упавшего приложения.
Установка отладочных пакетов
В настоящее время несколько зеркал распространяют отладочные пакеты в доступных репозиториях. Это спонсируемые зеркала, контролируемые Arch Linux, которым предоставляется доступ к отладочным репозиториям.
- https://america.mirror.pkgbuild.com
- https://asia.mirror.pkgbuild.com
- https://europe.mirror.pkgbuild.com
- https://geo.mirror.pkgbuild.com (зеркало GeoDNS)
Можно установить пакет напрямую из репозитория. Например:
# pacman -U https://geo.mirror.pkgbuild.com/core-debug/os/x86_64/zstd-debug-1.5.2-2-x86_64.pkg.tar.zst
Другой вариант — добавить репозитории в конфигурацию pacman.
Поместите зеркало с отладочными пакетами в качестве первого в файле mirrorlist:
Пересборка пакетов
Если отладочная информация недоступна через debuginfod (например, если пакет собран из AUR), то его можно пересобрать из исходников с включением отладки. Получение файлов PKGBUILD от пакетов из официальных репозиториев описано в статье Arch Build System (Русский); работа с пакетами из AUR описана в статье Arch User Repository (Русский)#Получение файлов.
Чтобы установить необходимые #Параметры компиляции, можно изменить настройки makepkg, если вы планируете использовать makepkg только для отладки. В других случаях меняйте файлы только тех пакетов, которые вы хотите пересобрать.
Параметры компиляции
С версии pacman 4.1 имеет отладочные флаги компиляции в и DEBUG_CXXFLAGS
. Для их использования включите опцию и отключите опцию .
Эти настройки включат компиляцию с отладочными символами и отключат их удаление из исполняемых файлов.
/etc/makepkg.conf
OPTIONS+=(debug !strip)
Для изменения параметров отдельного пакета измените его :
В качестве альтернативы можно поместить информацию об отладке в отдельный пакет, включив обе опции и . Тогда отладочные символы будут удалены из основного пакета и помещены вместе с исходным кодом в отдельный пакет . Это может пригодиться, если пакет содержит очень большие бинарные файлы (например, больше гигабайта с включенными отладочными символами), так как они могут привести к зависаниям и другому странному поведению.
glibc
Некоторые пакеты, к примеру glibc, всё равно удаляют отладочные символы. Проверьте на наличие подобных команд:
И удалите их по необходимости.
Clang
Пакеты, использующие Clang в качестве компилятора, не будут собираться с опцией из-за того, что флаг не обрабатывается (например, ).
Добавьте следующее в начало функции build()
нужного пакета:
Сборка и установка пакета
Соберите пакет командой , находясь в одном каталоге с файлом . Это может занять некоторое время:
$ makepkg
Установка собранного пакета:
# pacman -U glibc-2.26-1-x86_64.pkg.tar.gz
Получение трассировки
Теперь можно получить backtrace (трассировку стека), например, с помощью gdb (GNU Debugger). Запуск осуществляется так:
# gdb /путь/к/файлу
или:
# gdb (gdb) exec /путь/к/файлу
Если путь присутствует в $PATH
, его можно не указывать.
Затем в введите и аргументы для передачи запускаемому файлу:
(gdb) run --no-daemon --verbose
После запуска выполните действия, приводящие к возникновению бага. Также можно включить логгирование происходящего командой:
(gdb) set logging file trace.log (gdb) set logging on
и затем:
(gdb) thread apply all bt full
для вывода трассировки в файл в каталоге, в котором был запущен . Для выхода введите:
(gdb) set logging off (gdb) quit
Также отладчик может подключиться к уже запущенному приложению, например:
# gdb --pid=$(pidof firefox) (gdb) continue
Для отладки уже упавшего приложения запустите на соответствующем дампе памяти.
Смотрите также
- Debian:HowToGetABacktrace
- Gentoo:Project:Quality Assurance/Backtraces
- Fedora:StackTraces
- GNOME - Getting Stack Traces
- gdb mini intro