「デバッグ/トレースを取得」の版間の差分

提供: ArchWiki
ナビゲーションに移動 検索に移動
(ページの作成:「Category:パッケージ開発 en:Debug - Getting Traces zh-CN:Debug - Getting Traces {{Related articles start}} {{Related|一般的なトラブルシュー...」)
 
(冒頭を翻訳)
(5人の利用者による、間の17版が非表示)
1行目: 1行目:
 
[[Category:パッケージ開発]]
 
[[Category:パッケージ開発]]
[[en:Debug - Getting Traces]]
+
[[en:Debugging/Getting traces]]
[[zh-CN:Debug - Getting Traces]]
+
[[pt:Debug - Getting Traces]]
 
{{Related articles start}}
 
{{Related articles start}}
 
{{Related|一般的なトラブルシューティング}}
 
{{Related|一般的なトラブルシューティング}}
8行目: 8行目:
 
{{Related articles end}}
 
{{Related articles end}}
 
この記事では Arch パッケージを作成するときにトレースを取得したり、開発者にソフトウェアのバグを報告するのに役立つデバッグ情報を集める方法を解説します。
 
この記事では Arch パッケージを作成するときにトレースを取得したり、開発者にソフトウェアのバグを報告するのに役立つデバッグ情報を集める方法を解説します。
  +
  +
通常、実行可能ファイルは、サイズを小さくするために、人間の読める情報が取り除かれています。それだけでなく、そもそも、拡張されたデバッグ情報も通常、実行ファイルに追加されないので、トレースの品質が大幅に劣化します。なので、デバッグ情報のあるトレースを得る前に、デバッグ情報を取り除かずにパッケージを再ビルドする必要があります。
  +
  +
発見したバグを開発者に知らせるときは完全なスタックトレースを使ってください。プログラムの開発に役に立ちます。
   
 
== パッケージの名前 ==
 
== パッケージの名前 ==
   
以下のようなデバッグメッセージを見とき:
+
以下のようなデバッグメッセージが表示され場合:
   
 
[...]
 
[...]
27行目: 31行目:
 
[...]
 
[...]
   
  +
{{ic|??}} はデバッグ情報が存在していないために関数を呼び出しているライブラリ・実行可能ファイルがわからないことを意味しています。同じように {{ic|(no debugging symbols found)}} と表示されたら、その下に出力されたファイルを確認してください。例えば [[pacman]] を使用して確認するには:
{{ic|??}} shows where debugging info is missing, as well as the name of library or executable which called the function. Similarly, when {{ic|(no debugging symbols found)}} appears, you should look for the stated file names. For example, with [[pacman]]:
 
   
# pacman -Qo /lib/libthread_db.so.1
+
$ pacman -Qo /lib/libthread_db.so.1
 
/lib/libthread_db.so.1 is owned by ''glibc'' 2.5-8
 
/lib/libthread_db.so.1 is owned by ''glibc'' 2.5-8
   
  +
パッケージの名前は {{Pkg|glibc}} でバージョンが 2.5-8 とわかりました。デバッグが必要なパッケージの数だけ同じ手順を繰り返してください。
The package is called {{Pkg|glibc}} in version 2.5-8. Repeat this step for every package that needs debugging.
 
   
== PKGBUILD ==
+
== Debuginfod ==
   
  +
[[公式リポジトリ]] でサポートしているパッケージ [https://debuginfod.archlinux.org/packages] では、[[debuginfod]] を使って HTTP で直接デバッグ情報を取得することができます。
ソースからパッケージをビルドするには、[[PKGBUILD]] ファイルが必要です。[[公式リポジトリ]]のパッケージについては [[ABS]] を、[[AUR]] のパッケージについては [[AUR#ビルドファイルを獲得]] を見てください。
 
   
  +
{{Pkg|zstd}} のデバッグシンボルをいくつかのソースファイルとともに取得する場合は、{{ic|debuginfod-find}} を利用できます。
== コンパイル設定 ==
 
  +
$ debuginfod-find debuginfo /usr/bin/zstd
  +
/home/user/.cache/debuginfod_client/70e1b456c5813658df6436a3deb71812e75a0267/debuginfo
  +
  +
$ debuginfod-find source /usr/bin/zstd /usr/src/debug/zstd-1.5.2/programs/fileio.c
  +
/home/user/.cache/debuginfod_client/70e1b456c5813658df6436a3deb71812e75a0267/source##usr##src##debug##zstd-1.5.2##programs##fileio.c
  +
  +
gdb のようなデバッガーは、debuginfod パッケージがインストールされるときに、これをバックグラウンドで使用します。
  +
  +
== Install debug packages ==
  +
  +
{{Note| Note the situation may have changed since {{#time:j. F Y|2 February 2022}} }}
  +
{{Note| Debug packages are not archived by Arch Linux on [[Arch Linux Archive]] }}
  +
  +
A few mirrors currently distribute debug packages in accessible repositories. These are sponsored mirrors controlled by Arch Linux and are given access to the debug repositories.
  +
  +
* https://america.mirror.pkgbuild.com
  +
* https://asia.mirror.pkgbuild.com
  +
* https://europe.mirror.pkgbuild.com
  +
  +
To install a package you can install it directly from the repository.
  +
  +
# pacman -U https://''area''.mirror.pkgbuild.com/core-debug/os/x86_64/zstd-debug-1.5.2-2-x86_64.pkg.tar.zst
  +
  +
Another option is to add the repositories to your pacman configuration.
  +
  +
{{hc|1=/etc/pacman.conf|2=
  +
[core-debug]
  +
Server = https://''area''.mirror.pkgbuild.com/$repo/os/$arch
  +
  +
[extra-debug]
  +
Server = https://''area''.mirror.pkgbuild.com/$repo/os/$arch
  +
  +
[community-debug]
  +
Server = https://''area''.mirror.pkgbuild.com/$repo/os/$arch
  +
  +
[multilib-debug]
  +
Server = https://''area''.mirror.pkgbuild.com/$repo/os/$arch
  +
  +
# Testing Repositories
  +
  +
[testing-debug]
  +
Server = https://''area''.mirror.pkgbuild.com/$repo/os/$arch
  +
  +
[community-testing-debug]
  +
Server = https://''area''.mirror.pkgbuild.com/$repo/os/$arch
  +
  +
[multilib-testing-debug]
  +
Server = https://''area''.mirror.pkgbuild.com/$repo/os/$arch
  +
}}
  +
  +
{{Warning|Debug packages from one [[ミラー]] are not compatible with regular packages from another mirror, if both mirrors are not in sync, and thus have mismatching builds. In this case, avoid mixing packages from different mirrors (this would result in a [[部分アップグレード]]), but point all repositories to the {{ic|debug}} mirror.}}
  +
  +
== Rebuild packages ==
  +
  +
If debug information is not exposed through ''debuginfod'' (for example, when the package originates from the [[AUR]]), then it can be rebuilt from source. See [[ABS]] for packages in the [[公式リポジトリ]], or [[AUR#Acquire build files]] for packages in the [[AUR]].
   
 
ここで、デバッグ目的でしか makepkg を使用しない場合は {{ic|makepkg}} のグローバルな設定ファイルを編集してください。そうではない場合は、リビルドしたいパッケージの PKGBUILD だけを修正してください。
 
ここで、デバッグ目的でしか makepkg を使用しない場合は {{ic|makepkg}} のグローバルな設定ファイルを編集してください。そうではない場合は、リビルドしたいパッケージの PKGBUILD だけを修正してください。
   
=== 一般 ===
+
=== コンパイル設定 ===
   
 
pacman 4.1 現在、{{ic|/etc/makepkg.conf}} のデバッグコンパイルフラグには {{ic|DEBUG_CFLAGS}} と {{ic|DEBUG_CXXFLAGS}} があります。これらを使うには、makepkg オプションの {{ic|debug}} を有効化して {{ic|strip}} を無効化してください。
 
pacman 4.1 現在、{{ic|/etc/makepkg.conf}} のデバッグコンパイルフラグには {{ic|DEBUG_CFLAGS}} と {{ic|DEBUG_CXXFLAGS}} があります。これらを使うには、makepkg オプションの {{ic|debug}} を有効化して {{ic|strip}} を無効化してください。
48行目: 107行目:
 
OPTIONS+=(debug !strip)
 
OPTIONS+=(debug !strip)
   
以上の設定で強制的にデバッグ情報が表示されるようにコンパイルされ、実行可能ファイルのストリップ無効になります ({{ic|strip}} を無効化しても、デバッグ情報は生成されますが、別 {{ic|''foo''-debug}} パッケージに移動れます)。
+
以上の設定で強制的にデバッグシンボルを生成するようにコンパイルされ、実行可能ファイルからシンボル排除されなくなります。特定のパッケージに適用するときは、PKGBUILD を修正してくだい:
 
この設定を一つのパッケージに適用するときは、PKGBUILD を修正してください:
 
   
 
options=(debug !strip)
 
options=(debug !strip)
   
  +
もしくは別のパッケージで {{ic|debug}} と {{ic|strip}} を有効にして、メインのパッケージからデバッグシンボルは取り除き、ソースコードを用意込みでデバッガでステップ実行できるよう、 {{ic|''foo''-debug}} パッケージでデバッグ情報を使うようにすることもできます。
Note that certain packages such as ''glibc'' are stripped regardless. Check the PKGBUILD for sections such as:
 
  +
  +
{{Note|新しくコンパイルしたデバッグパッケージをインストールするだけでは不十分です。デバッガは関連するライブラリや実行ファイルと同じビルドからデバッグシンボルが含まれたファイルを確認するためです。再コンパイルしたパッケージを両方ともインストールしてください。Arch ではデバッグシンボルファイルは {{ic|/usr/lib/debug}} に、ソースコードは {{ic|/usr/src/debug}} にインストールされます。デバッグパッケージについて詳しくは [https://sourceware.org/gdb/onlinedocs/gdb/Separate-Debug-Files.html GDB のドキュメント] を参照してください。}}
  +
  +
==== Glibc ====
  +
  +
''glibc'' など特定のパッケージは設定に関係なくデバッグ情報が取り除かれます。PKGBUILD の中を確認してください:
   
 
{{bc|<nowiki>
 
{{bc|<nowiki>
61行目: 124行目:
 
usr/bin/{pcprofiledump,pldd,rpcgen,sln,sprof} \
 
usr/bin/{pcprofiledump,pldd,rpcgen,sln,sprof} \
 
usr/lib/getconf/*
 
usr/lib/getconf/*
[[ $CARCH = "i686" ]] && strip $STRIP_BINARIES usr/bin/lddlibc4
 
   
 
strip $STRIP_STATIC usr/lib/*.a
 
strip $STRIP_STATIC usr/lib/*.a
72行目: 134行目:
 
</nowiki>}}
 
</nowiki>}}
   
  +
そして必要であれば記述を削除してください。
And remove them where appropriate.
 
   
=== Qt ===
+
==== Clang ====
   
  +
Packages using [[Clang]] as the compiler will not build with the {{ic|debug}} option due to the debug flag {{ic|-fvar-tracking-assignments'}} not being handled (e.g. {{Pkg|js78}}).
In addition to the previous general settings, pass {{ic|-developer-build}} option to the {{ic|configure}} script in the {{ic|PKGBUILD}}. By default, {{ic|-developer-build}} passes {{ic|-Werror}} to the compiler, which may cause the compilation to fail. To avoid compilation errors, you may need pass {{ic|-no-warnings-are-errors}}, too.
 
   
  +
Add the following at the top of the {{ic|build()}} function to only remove the flag for the affected package:
{{Note|
 
Compiling Qt with {{Pkg|qtwebkit}} installed may cause compilation errors. Hence, remove qtwebkit package temporarily from your system. Use the following command in order to ignore any dependencies on qtwebkit.
 
   
  +
{{bc|1=
# pacman -Rdd qtwebkit
 
  +
build() {
 
  +
CFLAGS=${CFLAGS/-fvar-tracking-assignments}
Do not forget to install qtwebkit after the compilation of Qt is finished, otherwise the programs that depend on it will not work!
 
  +
CXXFLAGS=${CXXFLAGS/-fvar-tracking-assignments}
  +
[...]
 
}}
 
}}
   
=== KDE アプリケーション ===
+
=== パッケージのビルドとイストール ===
 
[[KDE]] と関連するプログラムは基本的に {{Pkg|cmake}} を使っています。{{ic|-DCMAKE_BUILD_TYPE}} を {{ic|Debug}} に変更してください。
 
 
== パッケージのビルドとインストール ==
 
   
 
PKGBUILD のディレクトリから {{ic|makepkg}} を使ってソースからパッケージを作成します。多少時間がかかります:
 
PKGBUILD のディレクトリから {{ic|makepkg}} を使ってソースからパッケージを作成します。多少時間がかかります:
   
# makepkg
+
$ makepkg
   
 
そしてビルドしたパッケージをインストールしてください:
 
そしてビルドしたパッケージをインストールしてください:
   
# pacman -U glibc-2.5-8-i686.pkg.tar.gz
+
# pacman -U glibc-2.26-1-x86_64.pkg.tar.gz
   
 
== トレースの取得 ==
 
== トレースの取得 ==
141行目: 200行目:
 
(gdb) continue
 
(gdb) continue
   
  +
クラッシュしたアプリケーションをデバッグしたいときは、[[コアダンプ#コアダンプの確認|コアダンプ]]に対して gdb を起動すると良いでしょう。
== まとめ ==
 
 
Use the complete stack trace to inform developers of a bug you have discovered before. This will be highly appreciated by them and will help to improve your favorite program.
 
   
 
== 参照 ==
 
== 参照 ==
   
  +
* [[Debian:HowToGetABacktrace]]
* [http://www.gentoo.org/proj/en/qa/backtraces.xml Gentoo Linux Documentation — How to get meaningful backtraces in Gentoo]
 
  +
* [[Gentoo:Project:Quality Assurance/Backtraces]]
* [http://fedoraproject.org/wiki/StackTraces Fedora - StackTraces]
 
  +
* [[Fedora:StackTraces]]
* [https://wiki.gnome.org/Community/GettingInTouch/Bugzilla/GettingTraces/Details#obtain-a-stacktrace GNOME - Getting Stack Traces]
 
  +
* [https://wiki.gnome.org/GettingInTouch/Bugzilla/GettingTraces/Details#Obtaining_a_stack_trace_.28the_easy_way.29 GNOME - Getting Stack Traces]
* [http://linux.bytesex.org/gdb.html gdb mini intro]
 
  +
* [https://linux.bytesex.org/gdb.html gdb mini intro]
  +
  +
{{TranslationStatus|Debugging/Getting traces|2022-02-03|715225}}

2022年4月30日 (土) 18:15時点における版

関連記事

この記事では Arch パッケージを作成するときにトレースを取得したり、開発者にソフトウェアのバグを報告するのに役立つデバッグ情報を集める方法を解説します。

通常、実行可能ファイルは、サイズを小さくするために、人間の読める情報が取り除かれています。それだけでなく、そもそも、拡張されたデバッグ情報も通常、実行ファイルに追加されないので、トレースの品質が大幅に劣化します。なので、デバッグ情報のあるトレースを得る前に、デバッグ情報を取り除かずにパッケージを再ビルドする必要があります。

発見したバグを開発者に知らせるときは完全なスタックトレースを使ってください。プログラムの開発に役に立ちます。

パッケージの名前

以下のようなデバッグメッセージが表示される場合:

[...]
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

パッケージの名前は glibc でバージョンが 2.5-8 とわかりました。デバッグが必要なパッケージの数だけ同じ手順を繰り返してください。

Debuginfod

公式リポジトリ でサポートしているパッケージ [1] では、debuginfod を使って HTTP で直接デバッグ情報を取得することができます。

zstd のデバッグシンボルをいくつかのソースファイルとともに取得する場合は、debuginfod-find を利用できます。

$ debuginfod-find debuginfo /usr/bin/zstd
/home/user/.cache/debuginfod_client/70e1b456c5813658df6436a3deb71812e75a0267/debuginfo

$ debuginfod-find source /usr/bin/zstd /usr/src/debug/zstd-1.5.2/programs/fileio.c
/home/user/.cache/debuginfod_client/70e1b456c5813658df6436a3deb71812e75a0267/source##usr##src##debug##zstd-1.5.2##programs##fileio.c

gdb のようなデバッガーは、debuginfod パッケージがインストールされるときに、これをバックグラウンドで使用します。

Install debug packages

ノート: Note the situation may have changed since 2. 2月 2022
ノート: Debug packages are not archived by Arch Linux on Arch Linux Archive

A few mirrors currently distribute debug packages in accessible repositories. These are sponsored mirrors controlled by Arch Linux and are given access to the debug repositories.

To install a package you can install it directly from the repository.

# pacman -U https://area.mirror.pkgbuild.com/core-debug/os/x86_64/zstd-debug-1.5.2-2-x86_64.pkg.tar.zst

Another option is to add the repositories to your pacman configuration.

/etc/pacman.conf
[core-debug]
Server = https://area.mirror.pkgbuild.com/$repo/os/$arch

[extra-debug]
Server = https://area.mirror.pkgbuild.com/$repo/os/$arch

[community-debug]
Server = https://area.mirror.pkgbuild.com/$repo/os/$arch

[multilib-debug]
Server = https://area.mirror.pkgbuild.com/$repo/os/$arch

# Testing Repositories

[testing-debug]
Server = https://area.mirror.pkgbuild.com/$repo/os/$arch

[community-testing-debug]
Server = https://area.mirror.pkgbuild.com/$repo/os/$arch

[multilib-testing-debug]
Server = https://area.mirror.pkgbuild.com/$repo/os/$arch
警告: Debug packages from one ミラー are not compatible with regular packages from another mirror, if both mirrors are not in sync, and thus have mismatching builds. In this case, avoid mixing packages from different mirrors (this would result in a 部分アップグレード), but point all repositories to the debug mirror.

Rebuild packages

If debug information is not exposed through debuginfod (for example, when the package originates from the AUR), then it can be rebuilt from source. See ABS for packages in the 公式リポジトリ, or AUR#Acquire build files for packages in the AUR.

ここで、デバッグ目的でしか makepkg を使用しない場合は makepkg のグローバルな設定ファイルを編集してください。そうではない場合は、リビルドしたいパッケージの PKGBUILD だけを修正してください。

コンパイル設定

pacman 4.1 現在、/etc/makepkg.conf のデバッグコンパイルフラグには DEBUG_CFLAGSDEBUG_CXXFLAGS があります。これらを使うには、makepkg オプションの debug を有効化して strip を無効化してください。

OPTIONS+=(debug !strip)

以上の設定で強制的にデバッグシンボルを生成するようにコンパイルされ、実行可能ファイルからシンボルが排除されなくなります。特定のパッケージに適用するときは、PKGBUILD を修正してください:

options=(debug !strip)

もしくは別のパッケージで debugstrip を有効にして、メインのパッケージからデバッグシンボルは取り除き、ソースコードを用意込みでデバッガでステップ実行できるよう、 foo-debug パッケージでデバッグ情報を使うようにすることもできます。

ノート: 新しくコンパイルしたデバッグパッケージをインストールするだけでは不十分です。デバッガは関連するライブラリや実行ファイルと同じビルドからデバッグシンボルが含まれたファイルを確認するためです。再コンパイルしたパッケージを両方ともインストールしてください。Arch ではデバッグシンボルファイルは /usr/lib/debug に、ソースコードは /usr/src/debug にインストールされます。デバッグパッケージについて詳しくは GDB のドキュメント を参照してください。

Glibc

glibc など特定のパッケージは設定に関係なくデバッグ情報が取り除かれます。PKGBUILD の中を確認してください:

strip $STRIP_BINARIES usr/bin/{gencat,getconf,getent,iconv,iconvconfig} \
                      usr/bin/{ldconfig,locale,localedef,nscd,makedb} \
                      usr/bin/{pcprofiledump,pldd,rpcgen,sln,sprof} \
                      usr/lib/getconf/*

strip $STRIP_STATIC usr/lib/*.a

strip $STRIP_SHARED usr/lib/{libanl,libBrokenLocale,libcidn,libcrypt}-*.so \
                    usr/lib/libnss_{compat,db,dns,files,hesiod,nis,nisplus}-*.so \
                    usr/lib/{libdl,libm,libnsl,libresolv,librt,libutil}-*.so \
                    usr/lib/{libmemusage,libpcprofile,libSegFault}.so \
                    usr/lib/{audit,gconv}/*.so

そして必要であれば記述を削除してください。

Clang

Packages using Clang as the compiler will not build with the debug option due to the debug flag -fvar-tracking-assignments' not being handled (e.g. js78).

Add the following at the top of the build() function to only remove the flag for the affected package:

build() {
  CFLAGS=${CFLAGS/-fvar-tracking-assignments}
  CXXFLAGS=${CXXFLAGS/-fvar-tracking-assignments}
[...]

パッケージのビルドとインストール

PKGBUILD のディレクトリから makepkg を使ってソースからパッケージを作成します。多少時間がかかります:

$ makepkg

そしてビルドしたパッケージをインストールしてください:

# pacman -U glibc-2.26-1-x86_64.pkg.tar.gz

トレースの取得

バックトレース (またはスタックトレース) は GNU Debugger gdb で取得できます。次を実行:

# gdb /path/to/file

または:

# gdb
(gdb) exec /path/to/file

既に $PATH 変数に実行可能ファイルが設定されている場合はパスは必要ありません。

次に、gdb の中で、起動したいプログラムに付けたい引数を付けて run を入力します、例:

(gdb) run --no-daemon --verbose

これでファイルの実行が開始されます。バグが再現する操作を行なってください。ログを出力するには以下を入力:

(gdb) set logging file trace.log
(gdb) set logging on

そして:

(gdb) thread apply all bt full

これで gdb が起動したディレクトリの中の trace.log にトレースが出力されます。終了するには、次を入力:

(gdb) set logging off
(gdb) quit
ヒント: Python で書かれているアプリケーションをデバッグするには:
# gdb /usr/bin/python
(gdb) run <python application>

実行中のアプリケーションをデバッグすることもできます、例:

 # gdb --pid=$(pidof firefox)
 (gdb) continue

クラッシュしたアプリケーションをデバッグしたいときは、コアダンプに対して gdb を起動すると良いでしょう。

参照

翻訳ステータス: このページは en:Debugging/Getting traces の翻訳バージョンです。最後の翻訳日は 2022-02-03 です。もし英語版に 変更 があれば、翻訳の同期を手伝うことができます。