受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: 19 / devel
此文档适用于不受支持的 PostgreSQL 版本。
您可能需要查看当前版本的相同页面,或上面列出的其他受支持版本。

29.13. 配置参数 #

逻辑复制需要设置若干配置选项。这些选项只在复制的一侧生效。

29.13.1. 发布端 #

wal_level 必须设置为 replicalogical

max_replication_slots 必须至少设置为预期连接的订阅数量,再加上一些用于表同步的预留。

逻辑复制槽还会受到 idle_replication_slot_timeout 的影响。

max_wal_senders 应至少设置为 max_replication_slots,再加上同时连接的 物理副本数量。

逻辑复制 walsender 还会受到 wal_sender_timeout 的影响。

29.13.2. 订阅端 #

max_active_replication_origins 必须至少设置为将添加到订阅端的订阅数量,再加上一些用于表同步的预留。

如果任何订阅启用了 retain_dead_tuplesmax_replication_slots 必须至少设置为 1。

max_logical_replication_workers 必须至少设置为订阅数量(用于主应用工作进程),再加上并行应用工作进程、 表同步工作进程和序列同步工作进程的预留。

可能还需要调整 max_worker_processes 以容纳复制工作进程,至少应为 (max_logical_replication_workers + 1)。注意,一些扩展和并行查询也会占用 max_worker_processes 的工作进程槽位。

max_sync_workers_per_subscription 控制订阅初始化或新增表时,可以并行同步多少张表。序列同步还需要一个额外工作者。

max_parallel_apply_workers_per_subscription 控制订阅参数 streaming = parallel 时,对进行中事务流式复制的并行度。

逻辑复制工作进程还会受到 wal_receiver_timeoutwal_receiver_status_intervalwal_retrieve_retry_interval 的影响。