他のバージョンの文書9.6 | 9.5 | 9.4 | 9.3 | 9.2 | 9.1 | 9.0 | 8.4 | 8.3 | 8.2 | 8.1 | 8.0 | 7.4 | 7.3 | 7.2

27.2. 統計情報コレクタ

PostgreSQL統計情報コレクタはサーバの活動状況に関する情報を収集し、報告するサブシステムです。 現在、コレクタはテーブルとインデックスへのアクセスをディスクブロックおよび個々の行単位で数えることができます。 またこれは、各テーブル内の総行数、および、各テーブルでのVACUUMやANALYZEの実施情報を追跡します。 また、ユーザ定義関数の呼ばれた回数、それぞれの消費した総時間をカウントします。

また、PostgreSQLは他のサーバプロセスによって現在実行されている問い合わせを正確に報告する機能を持ちます。 これはコレクタプロセスから独立している機能です。

27.2.1. 統計情報収集のための設定

統計情報の収集によって問い合わせの実行に少しオーバーヘッドが加わりますので、システムは情報を収集するようにもしないようにも設定することができます。 これは通常はpostgresql.conf内で設定される、設定パラメータによって制御されます (設定パラメータの設定についての詳細は第18章を参照してください)。

track_countsパラメータは、テーブルおよびインデックスアクセスに関する統計情報を収集するかどうか制御します。

track_functionsパラメータは、ユーザ定義関数の使用状況を追跡するかどうかを指定できます。

track_activitiesパラメータにより、すべてのサーバプロセスで現在実行されているコマンドを監視することができます。

通常、これらの変数は全てのサーバプロセスに適用できるようにpostgresql.conf内で設定されます。 しかし、SETコマンドを使用して、個別のセッションで有効または無効にすることができます (一般ユーザがその活動を管理者に隠すことを防止するために、スーパーユーザのみがSETを使用してこれらのパラメータを変更することができます。)

統計情報コレクタはバックエンドと必要な情報(自動バキュームに関するものも含む)を収集し、一時ファイルへ送信します。。これらのファイルはpg_stat_tmpサブディレクトリに格納されます。 postmasterがシャットダウンした際は、統計情報データの永続的なコピーがglobalサブディレクトリに格納されます。性能向上のため、stats_temp_directoryパラメータでRAMベースのファイルシステムを指定することで、物理I/Oの要求を減らすことができます。

27.2.2. 収集した統計情報の表示

統計情報の収集結果を表示するための、多くの定義済みのビューがあり、表27-1に一覧表示されています。 他にも、基礎的な統計情報関数を使用した独自のビューを構築することもできます。

この統計情報を使用して、現在の活動状況を監視する場合、この情報は即座に更新されないことを認識することが重要です。 個別のサーバプロセスは、待機状態になる直前に、新しい統計情報に関する数をコレクタに送信します。 ですので、実行中の問い合わせやトランザクションは表示上の総和には影響を与えません。 また、コレクタ自体もおよそPGSTAT_STAT_INTERVAL(サーバ構築時に変更しない限り500)ミリ秒に一度新しい報告を出力します。 ですので、表示上の情報は実際の活動から遅れて表示されます。 しかし、track_activitiesで収集される現在の問い合わせの情報は常に最新です。

この他の重要なポイントは、いつサーバプロセスが統計情報を表示するように尋ねられるかです。 サーバプロセスは、まずコレクタによって発行された最も最近の報告を取り出します。 そして、現在のトランザクションが終わるまで、全ての統計情報ビューと関数においてこのスナップショットを使用し続けます。 ですから、現在のトランザクションを続けている間、統計情報は一定の情報を示します。 同様に、全セッションの現在の問い合わせに関する情報も、そうした情報がトランザクションで最初に要求された時に収集され、そのトランザクションの間同じ情報が表示されます。 これはバグではなく、特徴です。 なぜなら、これにより、知らない間に値が変更することを考慮することなく、統計情報に対して複数の問い合わせを実行し、その結果を相関することができるからです。 しかし、各問い合わせで新しい結果を取り出したい場合は、確実にトランザクションブロックの外側でその問い合わせを行ってください。 他にもpg_stat_clear_snapshot()を呼び出すこともできます。 これは現在のトランザクションの統計情報スナップショットを(もしあれば)破棄します。 次に統計情報を使用する場合に新しいスナップショットを取り出すことになります。

トランザクションからは、pg_stat_xact_all_tablespg_stat_xact_sys_tablespg_stat_xact_user_tablespg_stat_xact_user_functions、およびこれらのビューの元となっている関数を通じて、自身の統計情報(まだコレクタに送られていない)も参照することができます。 これらの数値はトランザクション中に継続的に更新されていくため上記の様な(静的な情報を示す)振る舞いとはなりません。

表 27-1. 標準統計情報ビュー

ビュー名説明
pg_stat_activityサーバプロセス当たり1行の形で、データベースのOID、データベース名、プロセスID、ユーザのOID、ユーザ名、アプリケーション名、クライアントアドレス、ホスト名(可能であれば)、クライアントアドレスとポート番号、サーバプロセスの開始時刻、現在のトランザクションの開始時刻、現在の問い合わせの実行開始時刻、プロセスの待機状態、そして現在の問い合わせのテキストを表示します。 現在の問い合わせについてのデータを報告する列はtrack_activitiesパラメータが有効な場合に表示されます。 さらに、その列は、ビューを確認するユーザがスーパーユーザ、あるいは報告対象プロセスを所有するユーザと同じである場合にのみ参照可能です。 クライアントのホスト名は、log_hostnameが設定されているか、pg_hba.confによる処理中にユーザのホスト名を探索する必要がある場合のみ有効となります。
pg_stat_bgwriterバックグランドライタによるクラスタ全体の統計情報、つまり、予定されるチェックポイント数、要求されるチェックポイント数、チェックポイントおよび整理用スキャンで書き込みされるバッファ数、およびあまりに多くのバッファを書き出したために整理用スキャンを中断したバックグランドライタの個数を、1行のみ表示します。 また、バックエンド(つまりバックグランドライタによるものではない)により書き込まれたバッファ、バックエンドが自身でfsyncを呼んだ(通常、バックエンド自身が書き込み場合でもバックグラウンドライタがそれらを制御します)回数、割り当てられた総バッファ量、そして最後に統計情報がリセットされた時間といった共有バッファプールに関する統計情報を含みます。
pg_stat_databaseデータベース当たり1行の形で、データベースのOID、データベース名、そのデータベースに接続する活動中のサーバプロセス数、そのデータベース中でコミットされたトランザクションの総数、ロールバックされたトランザクションの総数、読み取られたディスクブロックの総数、バッファヒット(つまり、バッファキャッシュに対象とするブロックが存在するために防止されたブロック読み取り要求)の総数、抽出・挿入・更新・削除により返された行数、(スタンバイサーバ上の)リカバリ処理と競合した結果キャンセルされた総問い合わせ数、そして最後に統計情報をリセットした時間を表示します。
pg_stat_database_conflictsデータベースあたり1行の形で、データベースのOID、データベース名、このデータベースに対するテーブルスペースの削除/ロックのタイムアウト/古いスナップショット/バッファへのピン保持/デッドロックが原因でキャンセルされた問い合わせ数を表示します。衝突はマスタサーバでは起こらないので、これらの情報はスタンバイサーバでのみ保持しています。
pg_stat_replication WAL送信プロセス当たり1行の形で、プロセスID、ユーザOID、ユーザ名、アプリケーション名、クライアントアドレス、ホスト名(可能であれば)、ポート番号、サーバプロセスが処理を開始した時間、そして現在のWAL送信状態と送信したトランザクションログ位置の情報を表示します。加えて、スタンバイサーバは最後に受信して書き込んだトランザクションログの位置、最後にディスクに書き込んだトランザクションログの位置、そして最後に再生したトランザクションログの位置を報告し、このビューに表示します。 もしスタンバイサーバのアプリケーション名がsynchronous_standby_namesに設定したものの一つと一致した場合、sync_priorityも表示されます。これは同期スタンバイが複数ある場合に、それぞれが同期スタンバイとなる優先順位です。 スーパーユーザのみ、各接続が正確になにを行っているのかを見ることができます。 クライアントのホスト名は、log_hostnameが設定されているか、pg_hba.confによる処理中にユーザのホスト名を探索する必要がある場合のみ有効となります。
pg_stat_all_tables現在のデータベース内の各テーブル(TOASTテーブルを含みます)に関する、テーブルのOID、スキーマおよびテーブル名、開始されたシーケンシャルスキャン数、シーケンシャルスキャンで取り出された実際の行数、(そのテーブルに属するすべてのインデックスに対して)開始されたインデックススキャン数、インデックススキャンで取り出された実際の行数、挿入、更新、削除された行数、HOT(つまり分離したインデックス更新がない)だった更新行の数、有効行数、無効行数、手動でそのテーブルがFULL無しでバキュームされた最後の時刻、自動バキュームデーモンによりバキュームされた最後の時刻、手動でアナライズされた前回の時刻、自動バキュームデーモンによりアナライズされた前回の時刻、手動でそのテーブルがFULL無しでバキュームされた回数、自動バキュームデーモンによりバキュームされた回数、手動でアナライズされた回数、自動バキュームデーモンによりアナライズされた回数です。
pg_stat_sys_tablesシステムテーブルのみが表示される点を除き、pg_stat_all_tablesと同じです。
pg_stat_user_tablesユーザテーブルのみが表示される点を除き、pg_stat_all_tablesと同じです。
pg_stat_xact_all_tablespg_stat_all_tablesと似ていますが、現在のトランザクションにて実施された処理結果をカウントします。(数値が見える時点では、これらの数値はpg_stat_all_tablesと関連するビューに含まれていません。) このビューでは、有効行数、無効行数、およびバキュームやアナライズの活動は表示しません。
pg_stat_xact_sys_tables システムテーブルのみが表示される点を除き、pg_stat_xact_all_tablesと同じです。
pg_stat_xact_user_tables ユーザテーブルのみが表示される点を除き、pg_stat_xact_all_tablesと同じです。
pg_stat_all_indexes現在のデータベース内の各インデックスに関する、テーブルとインデックスのOID、スキーマ、テーブルとインデックスの名前、開始されたインデックススキャン数、インデックススキャンによって読み取られたインデックス項目数、インデックスを使用した単純なインデックススキャンで取り出された実際のテーブル行の数。
pg_stat_sys_indexesシステムテーブルのインデックスのみが表示される点を除き、pg_stat_all_indexesと同じです。
pg_stat_user_indexesユーザテーブルのインデックスのみが表示される点を除き、pg_stat_all_indexesと同じです。
pg_statio_all_tables現在のデータベース内の各テーブル(TOASTテーブルを含みます)に関する、テーブルのOID、スキーマとテーブル名、そのテーブルから読み取られたディスクブロックの総数、バッファヒット数、そのテーブルに関する全てのインデックスから読み取られたディスクブロック数とバッファヒット数、(存在する場合)そのテーブルの補助的なTOASTテーブルから読み取られたディスクブロック数とバッファヒット数、TOASTテーブルのインデックスから読み取られたディスクブロック数とバッファヒット数。
pg_statio_sys_tablesシステムテーブルのみが表示される点を除き、pg_statio_all_tablesと同じです。
pg_statio_user_tablesユーザテーブルのみが表示される点を除き、pg_statio_all_tablesと同じです。
pg_statio_all_indexes現在のデータベース内の各インデックスに関する、テーブルとインデックスのOID、スキーマ、テーブルおよびインデックスの名前、そのインデックスから読み取られたディスクブロック数とバッファヒット数。
pg_statio_sys_indexesシステムテーブルのインデックスのみが表示される点を除き、pg_statio_all_indexes と同じです。
pg_statio_user_indexesユーザテーブルのインデックスのみが表示される点を除き、pg_statio_all_indexesと同じです。
pg_statio_all_sequences現在のデータベース内の各シーケンスオブジェクトに関する、シーケンスのOID、スキーマとシーケンスの名前、そのシーケンスから読み取られたディスクブロック数とバッファヒット数。
pg_statio_sys_sequencesシステムシーケンスのみが表示される点を除き、pg_statio_all_sequencesと同じです (現時点では、システムシーケンスは定義されていませんので、このビューは常に空です)。
pg_statio_user_sequencesユーザシーケンスのみが表示される点を除き、pg_statio_all_sequencesと同じです。
pg_stat_user_functions追跡された全ての関数に関する、関数のOID、スキーマ、関数名、呼ばれた回数、総処理時間、関数自身のみの処理時間。 関数自身の処理時間とは、関数自身が消費した総時間であり、総処理時間とは関数内で呼ばれている別の関数の消費時もを含めたものです。 時間の単位はミリ秒です。
pg_stat_xact_user_functions pg_stat_user_functionsと似ていますが、現在のトランザクション中に呼び出されたものだけをカウントします。 (数値が見える時点では、これらの数値はpg_stat_user_functionsに含まれていません。)

インデックス単位の統計情報は、どのインデックスが使用され、どの程度効果があるのかを評価する際に、特に有用です。

インデックスは直接的、または"ビットマップスキャン"経由で使用することができます。 ビットマップスキャンでは、複数のインデックスの出力をANDまたはOR規則を使って組み合わせることができます。 そのため、ビットマップスキャンが使用されると、個々のヒープ行の取り出しと特定のインデックスとを関連付けることは困難です。 したがって、ビットマップスキャンは使用したインデックスに関するpg_stat_all_indexes.idx_tup_readの数を増やします。 さらに、そのテーブルに関するpg_stat_all_tables.idx_tup_fetchの数も増やします。 しかし、pg_stat_all_indexes.idx_tup_fetchを変更しません。

注意: PostgreSQL 8.1より前では、idx_tup_read の値とidx_tup_fetchの値は基本的には常に同じでした。 idx_tup_readはインデックスから取り出したインデックス項目数を数え、一方でidx_tup_fetchはテーブルから取り出した有効な行数を数えますので、ビットマップスキャンを考慮しなくても、この2つの値が異なることがあり得るようになりました。 インデックスを使用して取り出した行に無効または未コミットの行があると、後者は少なくなります。

pg_statio_ビューは主に、バッファキャッシュの効率を評価する際に有用です。 実ディスク読み取りの数がバッファヒットの数よりもかなり少ないのであれば、そのキャッシュはカーネル呼び出しを行うことなく、ほとんどの読み取り要求を満足させています。 しかし、PostgreSQLバッファキャッシュに存在しないデータはカーネルのI/Oキャッシュにある可能性があり、そのため、物理的な読み取りを行うことなく取り出される可能性があるというPostgreSQLのディスクI/Oの取り扱いのため、これらの統計情報は、完全な論拠を提供しません。 PostgreSQLのI/O動作に関するより詳細な情報を入手したいのであれば、PostgreSQL統計情報コレクタとカーネルのI/Oの取り扱いの監視を行うオペレーティングシステムユーティリティを組み合わせることを勧めます。

統計情報を参照する他の方法は、上述の標準ビュー同様に、基礎的な統計情報アクセス関数を使用した問い合わせを作成することで設定することができます。 これらの関数は表27-2にリストされています。データベースごとのアクセス関数は、どのデータベースに対して報告するのかを識別するためにデータベースのOIDを受け付けます。 テーブルごと、インデックスごとの関数はテーブルの、もしくはインデックスのOIDを受け付けます。 関数呼び出しに関する統計情報の関数は、関数のOIDを受け付けます。(この関数を使用して参照できるテーブルとインデックス、及び関数は現在のデータベース内のものだけであることに注意してください)。 サーバプロセスごとのアクセス関数はサーバプロセスID番号を受け付けます。 取り得る範囲は1から現時点で活動中のサーバプロセスの数までです。

表 27-2. 統計情報アクセス関数

関数戻り値の型説明
pg_stat_get_db_numbackends(oid)integerデータベース内で活動中のサーバ数。
pg_stat_get_db_xact_commit(oid)bigintデータベース内でコミットされたトランザクション数。
pg_stat_get_db_xact_rollback(oid)bigintデータベース内でロールバックされたトランザクション数。
pg_stat_get_db_blocks_fetched(oid)bigintデータベースに関する、ディスクブロック抽出要求数。
pg_stat_get_db_blocks_hit(oid)bigintデータベースに関する、ディスクブロック要求の内キャッシュに存在した数。
pg_stat_get_db_tuples_returned(oid)bigintデータベースに関する、返されるタプル数。
pg_stat_get_db_tuples_fetched(oid)bigintデータベースに関する、抽出されるタプル数。
pg_stat_get_db_tuples_inserted(oid)bigintデータベースに関する、挿入されるタプル数。
pg_stat_get_db_tuples_updated(oid)bigintデータベースに関する、更新されるタプル数。
pg_stat_get_db_tuples_deleted(oid)bigintデータベースに関する、削除されるタプル数。
pg_stat_get_db_conflict_tablespace(oid)bigint データベースに関するテーブルスペースの削除とリカバリ処理が衝突した結果キャンセルされた問い合わせ数。
pg_stat_get_db_conflict_lock(oid)bigint データベースに関するロックとリカバリ処理が衝突した結果キャンセルされた問い合わせ数。
pg_stat_get_db_conflict_snapshot(oid)bigint データベースに関する古いスナップショットとリカバリ処理が衝突した結果キャンセルされた問い合わせ数。
pg_stat_get_db_conflict_bufferpin(oid)bigint データベースに関するピン留めされたバッファとリカバリ処理が衝突した結果キャンセルされた問い合わせ数。
pg_stat_get_db_conflict_startup_deadlock(oid)bigint データベースに関するデッドロックとリカバリ処理が衝突した結果キャンセルされた問い合わせ数。
pg_stat_get_db_stat_reset_time(oid)timestamptz データベースの統計情報がリセットされた最終時間。各データベースへの最初の接続時のシステム時間に初期化されます。このリセット時間はpg_stat_resetをデータベース上で呼び出す際だけでなく、テーブルやインデックスに対して実施されるpg_stat_reset_single_table_countersの実行時にも更新されます。
pg_stat_get_numscans(oid)bigint引数がテーブルの場合、シーケンシャルスキャンの実行回数。 引数がインデックスの場合インデックススキャンの実行回数。
pg_stat_get_tuples_returned(oid)bigint引数がテーブルの場合、シーケンシャルスキャンによって読み取られた行数。 引数がインデックスの場合、返されたインデックス項目数。
pg_stat_get_tuples_fetched(oid)bigint引数がテーブルの場合、ビットマップスキャンで抽出されたテーブル行の数。 引数がインデックスの場合、このインデックスを使用した単純なインデックススキャンで抽出された、テーブル行の数。
pg_stat_get_tuples_inserted(oid)bigintテーブルに挿入された行数。
pg_stat_get_tuples_updated(oid)bigintテーブルで更新された行数(HOT更新を含む)。
pg_stat_get_tuples_deleted(oid)bigintテーブルで削除された行数。
pg_stat_get_tuples_hot_updated(oid)bigintテーブルでHOT更新された行数。
pg_stat_get_live_tuples(oid)bigintテーブル内の有効行数。
pg_stat_get_dead_tuples(oid)bigintテーブル内の無効行数。
pg_stat_get_blocks_fetched(oid)bigintテーブルまたはインデックスに関する、ディスクブロック抽出要求数。
pg_stat_get_blocks_hit(oid)bigintテーブルまたはインデックスに関する、ディスクブロック抽出要求の内キャッシュ内に存在した数。
pg_stat_get_last_vacuum_time(oid)timestamptzテーブルに対してユーザが行ったFULL無しバキュームの最終時刻。
pg_stat_get_last_autovacuum_time(oid)timestamptzテーブルに対して自動バキュームデーモンが行ったバキュームの最終時刻。
pg_stat_get_last_analyze_time(oid)timestamptzテーブルに対してユーザが行ったアナライズの最終時刻。
pg_stat_get_last_autoanalyze_time(oid)timestamptzテーブルに対して自動バキュームデーモンが行ったアナライズの最終時刻。
pg_stat_get_vacuum_count(oid)bigint テーブルに対してユーザが行ったFULL無しバキュームの回数。
pg_stat_get_autovacuum_count(oid)bigint テーブルに対して自動バキュームデーモンが行ったバキュームの回数。
pg_stat_get_analyze_count(oid)bigint テーブルに対してユーザが行ったアナライズの回数。
pg_stat_get_autoanalyze_count(oid)bigint テーブルに対して自動バキュームデーモンが行ったアナライズの回数。
pg_stat_get_xact_numscans(oid)bigint 引数がテーブルの場合、現在のトランザクションにおけるシーケンシャルスキャンの実行回数。 引数がインデックスの場合、現在のトランザクションにおけるインデックススキャンの実行回数。
pg_stat_get_xact_tuples_returned(oid)bigint 引数がテーブルの場合、現在のトランザクションにおけるシーケンシャルスキャンによって読み取られた行数。 引数がインデックスの場合、現在のトランザクションにおいて返されたインデックス項目数。
pg_stat_get_xact_tuples_fetched(oid)bigint 引数がテーブルの場合、現在のトランザクションにおけるビットマップスキャンで抽出されたテーブル行の数。 引数がインデックスの場合、現在のトランザクションにおけるこのインデックスを使用した単純なインデックススキャンで抽出された、テーブル行の数。
pg_stat_get_xact_tuples_inserted(oid)bigint 現在のトランザクションにおけるテーブルに挿入された行数。
pg_stat_get_xact_tuples_updated(oid)bigint 現在のトランザクションにおけるテーブルで更新された行数(HOT更新を含む)。
pg_stat_get_xact_tuples_deleted(oid)bigint 現在のトランザクションにおけるテーブルで削除された行数。
pg_stat_get_xact_tuples_hot_updated(oid)bigint 現在のトランザクションにおけるテーブルでHOT更新された行数。
pg_stat_get_xact_blocks_fetched(oid)bigint 現在のトランザクションにおけるテーブルまたはインデックスに関する、ディスクブロック抽出要求数。
pg_stat_get_xact_blocks_hit(oid)bigint 現在のトランザクションにおけるテーブルまたはインデックスに関する、ディスクブロック抽出要求の内キャッシュ内に存在した数。
pg_backend_pid()integer現在のセッションに接続するサーバプロセスのプロセスID。
pg_stat_get_activity(integer)setof recordPIDが指定された場合、それに該当するバックエンドの情報のレコード、NULLが指定された場合はシステム上のアクティブな各バックエンドの情報がレコードが返されます。返される情報内容はpg_stat_activityの一部と同じです。
pg_stat_get_function_calls(oid)bigint関数が呼ばれた回数。
pg_stat_get_function_time(oid)bigint関数内で消費された時間(マイクロ秒)。この関数で呼ばれた別の関数の消費時間も含まれています。
pg_stat_get_function_self_time(oid)bigintこの関数のみで消費された時間。この関数から呼ばれた別の関数の消費時間は含まれていません。
pg_stat_get_xact_function_calls(oid)bigint 現在のトランザクションにおける関数が呼ばれた回数。
pg_stat_get_xact_function_time(oid)bigint 現在のトランザクションにおける関数内で消費された時間(マイクロ秒)。この関数で呼ばれた別の関数の消費時間も含まれています。
pg_stat_get_xact_function_self_time(oid)bigint 現在のトランザクションにおけるこの関数のみで消費された時間。この関数から呼ばれた別の関数の消費時間は含まれていません。
pg_stat_get_backend_idset()setof integer現在活動中のサーバプロセス数のセット(1から活動中のサーバプロセス数までの間)。 以下の使用例を参照してください。
pg_stat_get_backend_pid(integer)integer指定されたサーバプロセスのプロセスID。
pg_stat_get_backend_dbid(integer)oid指定されたサーバプロセスのデータベースID。
pg_stat_get_backend_userid(integer)oid指定されたサーバプロセスのユーザID。
pg_stat_get_backend_activity(integer)text指定されたサーバプロセスの現在の問い合わせ。 ただし、現在のユーザがスーパーユーザの場合、または問い合わせ先セッションのユーザの同一の場合(かつ、track_activitiesが有効の場合)のみです。
pg_stat_get_backend_waiting(integer)boolean指定されたサーバプロセスがロック待ち状態の場合に真です。 しかし、現在のユーザがスーパーユーザの場合、または、問い合わせを行ったユーザと同一の場合(かつ、track_activitiesが有効の場合)に限ります。
pg_stat_get_backend_activity_start(integer)timestamp with time zone指定されたサーバプロセスが実行中の問い合わせを開始した時刻。 ただし、現在のユーザがスーパーユーザの場合、または問い合わせ先セッションのユーザの同一の場合(かつ、track_activitiesが有効の場合)のみです。
pg_stat_get_backend_xact_start(integer)timestamp with time zone指定したサーバプロセスで現在実行中のトランザクションが始まった時刻。 ただし、現在のユーザがスーパーユーザの場合、または問い合わせ先セッションのユーザの同一の場合(かつ、track_activitiesが有効の場合)のみです。
pg_stat_get_backend_start(integer)timestamp with time zone指定されたサーバプロセスが開始した時刻。 現在のユーザがスーパーユーザまたは問い合わせを行っているセッションユーザと同じでない場合はNULL。
pg_stat_get_backend_client_addr(integer)inet指定されたサーバプロセスに接続するクライアントのIPアドレス。 Unixドメインソケット経由の接続の場合はNULL。 また、現在のユーザがスーパーユーザまたは問い合わせを行っているセッションユーザと同じでない場合もNULL。
pg_stat_get_backend_client_port(integer)integer指定されたサーバプロセスに接続するクライアントのTCPポート番号。 Unixドメインソケット経由の接続の場合は-1。 現在のユーザがスーパーユーザまたは問い合わせを行っているセッションユーザと同じでない場合はNULL。
pg_stat_get_bgwriter_timed_checkpoints()bigintcheckpoint_timeout時間経過したために)バックグランドライタが予定されたチェックポイントを起動した回数。
pg_stat_get_bgwriter_requested_checkpoints()bigintcheckpoint_segmentsを超えた、あるいはCHECKPOINTが呼び出されたという理由によりバックエンドからの要求に基づき、バックグランドライタがチェックポイントを起動した回数。
pg_stat_get_bgwriter_buf_written_checkpoints()bigintバックグランドライタがチェックポイント期間中に書き込んだバッファ数。
pg_stat_get_bgwriter_buf_written_clean()bigintダーティページの書き出し処理のためにバックグランドライタが書き出したバッファ数。
pg_stat_get_bgwriter_maxwritten_clean()bigintバッファへの書き出しがbgwriter_lru_maxpagesパラメータで指定した数以上発生したためにバックグランドライタが書き出し用スキャンを中断した回数。
pg_stat_get_bgwriter_stat_reset_time()timestamptz バックグラウンドライタの最後の統計情報リセット時間。データベースクラスタの上でpg_stat_reset_shared('bgwriter')が実施された際に更新されます。
pg_stat_get_buf_written_backend()bigint新しいバッファ割り当てを行う必要があったためにバックエンドにより書き込まれたバッファ数。
pg_stat_get_buf_alloc()bigint割り当てられたバッファの総数。
pg_stat_clear_snapshot()void現在の統計情報スナップショットを破棄します。
pg_stat_reset()void現在のデータベースに関する統計カウンタすべてをゼロにリセットします(スーパーユーザ権限が必要です)。
pg_stat_reset_shared(text)voidデータベースクラスタの共有統計情報カウンタの一部をゼロに戻します(スーパーユーザ権限が必要です)。pg_stat_reset_shared('bgwriter')を呼び出すと、pg_stat_bgwriterで示される値すべてがゼロになります。
pg_stat_reset_single_table_counters(oid)void現在のデータベース内にある、ひとつのテーブルあるいはインデックスの統計情報をゼロにリセットします(スーパーユーザ権限が必要です)。
pg_stat_reset_single_function_counters(oid)void現在のデータベース内にある、ひとつの関数の統計情報をゼロにリセットします(スーパーユーザ権限が必要です)。

注意: pg_stat_get_blocks_fetchedからpg_stat_get_blocks_hitを引くと、そのテーブル、インデックス、データベースに対して発行されたカーネルのread()コール数がわかります。実際の物理的な読み取り数は、カーネルレベルのバッファ処理のために通常これより小さくなります。*_blks_readの統計情報カラムはfetched数からhit数を差し引いた結果を用いています。

バックエンドに関する情報にアクセスする関数は、全てバックエンドのIDでインデックス化されています。ただし、pg_stat_get_activityだけはPIDでインデックス化されています。pg_stat_get_backend_idset関数は、活動中のサーバプロセスそれぞれについて1行を作成する簡便な方法を提供します。例えば、全てのサーバプロセスのPIDと現在の問い合わせを表示するには、以下を行います。

SELECT pg_stat_get_backend_pid(s.backendid) AS procpid,
       pg_stat_get_backend_activity(s.backendid) AS current_query
    FROM (SELECT pg_stat_get_backend_idset() AS backendid) AS s;