第30章 ftrace を使用したレイテンシーのトレース
ftrace ユーティリティーは、RHEL for Real Time Kernel で提供される診断機能の 1 つです。ftrace は、開発者がユーザー空間外で発生するレイテンシーおよびパフォーマンスの問題を分析およびデバッグするのに使用できます。ftrace ユーティリティーには、さまざまな方法でユーティリティーを使用できるさまざまなオプションがあります。これは、コンテキストスイッチの追跡、優先順位の高いタスクでのウェイクアップにかかる時間の測定、割り込みが無効になっている期間の測定、特定の期間中に実行されたカーネル関数のリストの表示に使用できます。
ftrace トレーサーなどの一部のトレーサーは、大量のデータ量を生成し、トレースログ分析を時間の消費タスクに切り替えます。ただし、トレーサーに対し、アプリケーションが重要なコードパスに到達した場合にのみ開始および終了するように指示することが可能です。
前提条件
- 管理者権限がある。
30.1. ftrace ユーティリティーを使用したレイテンシーの追跡 リンクのコピーリンクがクリップボードにコピーされました!
ftrace ユーティリティーを使用して、レイテンシーを追跡できます。
手順
システムで利用可能なトレーサーを表示します。
# cat /sys/kernel/debug/tracing/available_tracers function_graph wakeup_rt wakeup preemptirqsoff preemptoff irqsoff function nopftraceのユーザーインターフェイスは、debugfs内の一連のファイルです。ftraceファイルは、/sys/kernel/debug/tracing/ディレクトリーにあります。/sys/kernel/debug/tracing/ディレクトリーに移動します。# cd /sys/kernel/debug/tracingトレースを有効にするとシステムのパフォーマンスに影響を及ぼす可能性があるため、このディレクトリーのファイルを変更することができるのは root ユーザーのみです。
トレースセッションを開始するには、以下を行います。
-
/sys/kernel/debug/tracing/available_tracersで利用可能なトレーサーのリストから、使用するトレーサーを選択します。 セレクターの名前を
/sys/kernel/debug/tracing/current_tracerに挿入します。# echo preemptoff > /sys/kernel/debug/tracing/current_tracer注記echo コマンドと '>' 1 つを合わせて使用する場合は、ファイル内の既存の値が上書きされます。ファイルに値を追記する場合は、代わりに '>>' を使用します。
-
function-traceオプションは、wakeup_rt、preemptirqsoffなどを使用してレイテンシーをトレースすると、関数のトレースが自動的に有効になり、オーバーヘッドが誇張される可能性があるため便利です。functionおよびfunction_graphのトレースが有効になっているかどうかを確認します。# cat /sys/kernel/debug/tracing/options/function-trace 1-
値を
1に設定すると、functionとfunction_graphのトレースが有効になります。 -
値が
0の場合は、functionおよびfunction_graphのトレースが無効になっていることを示します。
-
値を
デフォルトでは、
functionおよびfunction_graphトレースは有効になっています。functionおよびfunction_graphのトレースのオン/オフを切り替えるには、/sys/kernel/debug/tracing/options/function-traceに適切な値を echo で追加します。# echo 0 > /sys/kernel/debug/tracing/options/function-trace # echo 1 > /sys/kernel/debug/tracing/options/function-trace重要echoコマンドを使用する場合は、値と>文字の間に空白文字を配置するようにしてください。0>、1>、および2>(空白文字なし) を使用するシェルプロンプトでは、標準入力、標準出力、および標準エラーを参照します。誤ってそれらを使用すると、トレースが予期せぬ出力になる可能性があります。/debugfs/tracing/ディレクトリー内のさまざまなファイルの値を変更して、トレーサーの詳細とパラメーターを調整します。以下に例を示します。
irqsoff、preemptoff、preempirqsoff、およびwakeupトレーサーは、レイテンシーを継続的に監視します。tracing_max_latencyに記録されたレイテンシーよりも大きいレイテンシーを記録すると、そのレイテンシーのトレースが記録され、tracing_max_latencyが新しい最大時間に更新されます。これにより、tracing_max_latencyは、最後にリセットされてから記録された最大のレイテンシーを常に表示します。最大レイテンシーをリセットするには、
0をtracing_max_latencyファイルに echo で追加します。# echo 0 > /sys/kernel/debug/tracing/tracing_max_latency設定された量よりも大きいレイテンシーのみを表示するには、マイクロ秒単位で量を echo で出力します。
# echo 200 > /sys/kernel/debug/tracing/tracing_max_latencyトレースのしきい値を設定すると、最大レイテンシー設定が上書きされます。しきい値より大きいレイテンシーが記録されると、最大レイテンシーに関係なく記録されます。トレースファイルを確認すると、最後に記録されたレイテンシーのみが表示されます。
しきい値を設定するには、それを超えるとレイテンシーを記録する必要があるマイクロ秒数を echo で出力します。
# echo 200 > /sys/kernel/debug/tracing/tracing_thresh
トレースログを表示します。
# cat /sys/kernel/debug/tracing/traceトレースログを保存するには、別のファイルにコピーします。
# cat /sys/kernel/debug/tracing/trace > /tmp/lat_trace_logトレースされている関数を表示します。
# cat /sys/kernel/debug/tracing/set_ftrace_filter-
/sys/kernel/debug/tracing/set_ftrace_filterで設定を編集して、トレースしている関数をフィルターにかけます。ファイルにフィルターが指定されていない場合、すべての関数がトレースされます。 フィルター設定を変更するには、トレースする関数名を echo で追記します。このフィルターでは、検索用語の先頭または末尾に '*' ワイルドカードを使用できます。
例は ftrace の例 を参照してください。