pg_logical_slot_peek_changes()

显示来自逻辑复制槽的可用更改的函数

pg_logical_slot_peek_changes() 是一个系统函数,它返回指定逻辑复制槽中的指定更改集,而不会消耗它们,这意味着相同的更改集可以被再次检索。

pg_logical_slot_peek_changes()PostgreSQL 9.4 中添加。

用法

pg_logical_slot_peek_changes ( slot_name name, upto_lsn pg_lsn, upto_nchanges integer, VARIADIC options text[] ) →
        setof record ( lsn pg_lsn, xid xid, data text )

返回的更改集将从复制槽的当前 restart_lsn 值开始。

如果 upto_lsnupto_nchanges 都为 NULL,则将返回直到可用 WAL 结束的所有更改。

options 参数允许提供由逻辑复制槽关联的输出插件定义的选项。

要检索更改并推进复制槽,请使用 pg_logical_slot_get_changes()pg_logical_slot_get_binary_changes()

变更历史

示例

使用 test_decoding 作为插件创建一个逻辑复制槽

postgres=# SELECT * FROM pg_create_logical_replication_slot('test_slot_1', 'test_decoding');
  slot_name  |    lsn
-------------+-----------
 test_slot_1 | 0/0/301D458
(1 row)

执行一些 WAL 活动,这里是通过向现有表插入一行来实现的

postgres=# INSERT INTO foo VALUES (1, clock_timestamp());
INSERT 0 1

然后可以使用 pg_logical_slot_peek_changes() 通过之前创建的逻辑复制槽重复查询此 WAL 活动

postgres=# SELECT * FROM pg_logical_slot_peek_changes('test_slot_1', NULL, NULL, 'include-xids', '0');
    lsn    | xid |                                       data                                       
-----------+-----+----------------------------------------------------------------------------------
 0/301D458 | 713 | BEGIN
 0/301D458 | 713 | table public.foo: INSERT: id[integer]:1 val[text]:'2021-09-05 21:56:25.88791+01'
 0/301D4E0 | 713 | COMMIT
(3 rows)

postgres=# SELECT * FROM pg_logical_slot_peek_changes('test_slot_1', NULL, NULL, 'include-xids', '0');
    lsn    | xid |                                       data                                       
-----------+-----+----------------------------------------------------------------------------------
 0/301D458 | 713 | BEGIN
 0/301D458 | 713 | table public.foo: INSERT: id[integer]:1 val[text]:'2021-09-05 21:56:25.88791+01'
 0/301D4E0 | 713 | COMMIT
(3 rows)

如果可用 WAL 被消耗,例如使用 pg_logical_slot_get_changes(),或者复制槽被向前移动(并且没有其他 WAL 活动发生),则先前返回的数据将不再可用

postgres=# SELECT * FROM pg_replication_slot_advance('test_slot_1', '0/301D4E0');
  slot_name  |  end_lsn  
-------------+-----------
 test_slot_1 | 0/301D4E0
(1 row)

postgres=# SELECT * FROM pg_logical_slot_peek_changes('test_slot_1', NULL, NULL, 'include-xids', '0');
 lsn | xid | data 
-----+-----+------
(0 rows)

分类

逻辑复制, 复制槽, 系统函数

另请参阅

pg_logical_slot_get_changes(), pg_logical_slot_get_binary_changes(), pg_logical_slot_peek_binary_changes()

反馈

在此 提交有关“pg_logical_slot_peek_changes()”的任何评论、建议或更正