auto_explain
モジュールは、手動でEXPLAINの実行を必要とせず、自動的に遅い文の実行計画をログ記録する手段を提供します。
大きなアプリケーションにおける最適化されていない問い合わせを追跡するのに特に有用です。
このモジュールはSQLでアクセスできる関数を提供しません。 使用するには、サーバに単に読み込ませます。 ある個別のセッションに読み込ませることができます。
LOAD 'auto_explain';
(実行するためにはスーパーユーザでなければなりません。)
より一般的な使用方法は、postgresql.conf
のsession_preload_librariesまたはshared_preload_librariesにauto_explain
を含めて、特定のまたはすべてのセッションで事前にロードしておくことです。
すると、想定外に低速な問い合わせを発生時に何も行うことなく追跡することができます。
当然ながらこのためのオーバーヘッドという代償があります。
auto_explain
の動作を制御するいくつかの設定パラメータが存在します。
デフォルトの動作は何もしないことなので、なんらかの結果を望むのであれば少なくともauto_explain.log_min_duration
を設定しなければならないことに注意してください。
auto_explain.log_min_duration
(integer
)
#
auto_explain.log_min_duration
は、文の実行計画がログに記録されるようになる、ミリ秒単位の最小の文実行時間です。
これを0
にすれば、すべての計画が記録されます。
-1
(デフォルト)は計画の記録を無効にします。
例えば、250ms
に設定すると、250ms以上実行する文すべてが記録されます。
スーパーユーザのみがこの設定を変更することができます。
auto_explain.log_parameter_max_length
(integer
)
#
auto_explain.log_parameter_max_length
は、問い合わせパラメータ値を記録するか制御します。
-1
という値(デフォルト)は、パラメータ値を完全に記録します。
0
はパラメータ値の記録を無効にします。
ゼロより大きい値は、各パラメータ値を指定されたバイト数に切り捨てます。
この設定を変更できるのは、スーパーユーザのみです。
auto_explain.log_analyze
(boolean
)
#
auto_explain.log_analyze
は、実行計画のログが取得されたときに出力されるものとして、単にEXPLAIN
出力ではなく、EXPLAIN ANALYZE
出力を行います。
このパラメータはデフォルトで無効です。
スーパーユーザのみがこの設定を変更できます。
このパラメータが有効の場合、計画ノードごとの時間的調整は事実上ログされるまで如何に時間が掛かろうと、全ての実行文に対して引き起こります。
極端に性能上のマイナスの影響が起こり得ます。
auto_explain.log_timing
を無効にすれば、得られる情報が少なくなるという犠牲を払って、性能の損失が改善されます。
auto_explain.log_buffers
(boolean
)
#
auto_explain.log_buffers
は実行計画のログを取得するときに、バッファ使用統計を出力するかどうかを制御します。
EXPLAIN
のBUFFERS
オプションと同じです。
auto_explain.log_analyze
パラメータが設定されていなければ、このパラメータは効果がありません。
このパラメータはデフォルトで無効です。
スーパーユーザのみがこの設定を変更することができます。
auto_explain.log_wal
(boolean
)
#
auto_explain.log_wal
は実行計画のログを取得するときに、WAL使用統計を出力するかどうかを制御します。
EXPLAIN
のWAL
オプションと同じです。
auto_explain.log_analyze
パラメータが設定されていなければ、このパラメータは効果がありません。
このパラメータはデフォルトで無効です。
スーパーユーザのみがこの設定を変更することができます。
auto_explain.log_timing
(boolean
)
#
auto_explain.log_timing
は、実行計画のログが取得されたときに、ノード毎の時間的調整情報を出力するかどうかを制御します。
EXPLAIN
のTIMING
オプションと同じです。
システムクロックを繰り返し読み出すことによるオーバーヘッドのため、システムの中には問い合わせが非常に遅くなるものがありますので、実際の行数のみ必要で正確な時刻は必要でない場合にはこのパラメータを無効にすると役に立つかも知れません。
auto_explain.log_analyze
が設定されていなければ、このパラメータは効果がありません。
デフォルトで有効です。
スーパーユーザのみがこの設定を変更することができます。
auto_explain.log_triggers
(boolean
)
#
auto_explain.log_triggers
により、実行計画のログを記録するときに、トリガ実行の統計を含めるようになります。
auto_explain.log_analyze
パラメータが設定されていなければ、このパラメータは効果がありません。
このパラメータはデフォルトで無効です。
スーパーユーザのみがこの設定を変更することができます。
auto_explain.log_verbose
(boolean
)
#
auto_explain.log_verbose
は、実行計画のログが取得されたときに、冗長な詳細が出力されるかどうかを制御します。
EXPLAIN
のVERBOSE
オプションと同じです。
このパラメータはデフォルトで無効です。
スーパーユーザのみがこの設定を変更できます。
auto_explain.log_settings
(boolean
)
#
auto_explain.log_settings
は、実行計画が記録される時に修正された設定オプションに関する情報を表示するかどうかを制御します。
問い合わせ計画に影響し、組み込みのデフォルトの値と異なる値であるオプションだけが出力に含まれます。
このパラメータはデフォルトで無効です。
スーパーユーザのみがこの設定を変更できます。
auto_explain.log_format
(enum
)
#
auto_explain.log_format
は使用するEXPLAIN
出力書式を選びます。
許容される値はtext
、xml
、json
、yaml
です。
デフォルトはtextです。
スーパーユーザのみがこの設定を変更することができます。
auto_explain.log_level
(enum
)
#
auto_explain.log_level
は、auto_explainが問い合わせ計画を記録するログレベルを選択します。
有効な値はDEBUG5
、DEBUG4
、DEBUG3
、DEBUG2
、DEBUG1
、INFO
、NOTICE
、WARNING
、LOG
です。
デフォルトはLOG
です。
スーパーユーザのみがこの設定を変更できます。
auto_explain.log_nested_statements
(boolean
)
#
auto_explain.log_nested_statements
により、入れ子状の文(関数内から実行される文)を考慮して記録するようになります。
無効ならば、最上位の問い合わせ計画のみが記録されます。
このパラメータはデフォルトで無効です。
スーパーユーザのみがこの設定を変更することができます。
auto_explain.sample_rate
(real
)
#
auto_explain.sample_rate
により、auto_explainは各セッションで一部の文の実行計画のみをログに記録するようになります。
デフォルトは1で、すべての問い合わせの実行計画をログに記録します。
入れ子になった文の場合には、実行計画がすべてログに記録されるか、全くされないかのどちらかです。
スーパーユーザのみがこの設定を変更できます。
スーパーユーザは自身のセッション内でその場で変更できますが、通常の使用では、これらパラメータはpostgresql.conf
に設定しなければなりません。
典型的な使用方法は以下のようになります。
# postgresql.conf session_preload_libraries = 'auto_explain' auto_explain.log_min_duration = '3s'
postgres=# LOAD 'auto_explain'; postgres=# SET auto_explain.log_min_duration = 0; postgres=# SET auto_explain.log_analyze = true; postgres=# SELECT count(*) FROM pg_class, pg_index WHERE oid = indrelid AND indisunique;
これにより、以下のようなログ出力が作成されます。
LOG: duration: 3.651 ms plan: Query Text: SELECT count(*) FROM pg_class, pg_index WHERE oid = indrelid AND indisunique; Aggregate (cost=16.79..16.80 rows=1 width=0) (actual time=3.626..3.627 rows=1 loops=1) -> Hash Join (cost=4.17..16.55 rows=92 width=0) (actual time=3.349..3.594 rows=92 loops=1) Hash Cond: (pg_class.oid = pg_index.indrelid) -> Seq Scan on pg_class (cost=0.00..9.55 rows=255 width=4) (actual time=0.016..0.140 rows=255 loops=1) -> Hash (cost=3.02..3.02 rows=92 width=4) (actual time=3.238..3.238 rows=92 loops=1) Buckets: 1024 Batches: 1 Memory Usage: 4kB -> Seq Scan on pg_index (cost=0.00..3.02 rows=92 width=4) (actual time=0.008..3.187 rows=92 loops=1) Filter: indisunique