pg_logicalinspectモジュールは、ロジカルデコーディングコンポーネントの内容を調査することができるSQL関数を提供します。
これにより実行中のPostgreSQLデータベースクラスタのシリアル化された論理スナップショットを調査することができ、デバッグや教育目的に役立ちます。
デフォルトでは、これらの関数の使用はスーパーユーザとpg_read_server_filesロールのメンバに制限されています。
スーパーユーザはGRANTを使うことによってほかのユーザにアクセスを許可できます。
pg_get_logical_snapshot_meta(filename text) returns record
#
サーバのpg_logical/snapshotsにあるスナップショットファイルの論理スナップショットメタデータを取得します。
filename引数はスナップショットファイル名を表します。
例:
postgres=# SELECT * FROM pg_ls_logicalsnapdir();
-[ RECORD 1 ]+-----------------------
name | 0-40796E18.snap
size | 152
modification | 2024-08-14 16:36:32+00
postgres=# SELECT * FROM pg_get_logical_snapshot_meta('0-40796E18.snap');
-[ RECORD 1 ]--------
magic | 1369563137
checksum | 1028045905
version | 6
postgres=# SELECT ss.name, meta.* FROM pg_ls_logicalsnapdir() AS ss,
pg_get_logical_snapshot_meta(ss.name) AS meta;
-[ RECORD 1 ]-------------
name | 0-40796E18.snap
magic | 1369563137
checksum | 1028045905
version | 6
filenameがスナップショットファイルと一致しない場合は、関数はエラーを発生します。
pg_get_logical_snapshot_info(filename text) returns record
#
サーバのpg_logical/snapshotsにあるスナップショットファイルの論理スナップショット情報を取得します。
filename引数はスナップショットファイル名を表します。
例:
postgres=# SELECT * FROM pg_ls_logicalsnapdir();
-[ RECORD 1 ]+-----------------------
name | 0-40796E18.snap
size | 152
modification | 2024-08-14 16:36:32+00
postgres=# SELECT * FROM pg_get_logical_snapshot_info('0-40796E18.snap');
-[ RECORD 1 ]------------+-----------
state | consistent
xmin | 751
xmax | 751
start_decoding_at | 0/40796AF8
two_phase_at | 0/40796AF8
initial_xmin_horizon | 0
building_full_snapshot | f
in_slot_creation | f
last_serialized_snapshot | 0/0
next_phase_at | 0
committed_count | 0
committed_xip |
catchange_count | 2
catchange_xip | {751,752}
postgres=# SELECT ss.name, info.* FROM pg_ls_logicalsnapdir() AS ss,
pg_get_logical_snapshot_info(ss.name) AS info;
-[ RECORD 1 ]------------+----------------
name | 0-40796E18.snap
state | consistent
xmin | 751
xmax | 751
start_decoding_at | 0/40796AF8
two_phase_at | 0/40796AF8
initial_xmin_horizon | 0
building_full_snapshot | f
in_slot_creation | f
last_serialized_snapshot | 0/0
next_phase_at | 0
committed_count | 0
committed_xip |
catchange_count | 2
catchange_xip | {751,752}
filenameがスナップショットファイルと一致しない場合は、関数はエラーを発生します。
Bertrand Drouvot <bertranddrouvot.pg@gmail.com>