在PostgreSQL中建立主从节点(也称为复制或流复制)可以通过以下步骤完成:
- 在主节点上配置
postgresql.conf
,启用wal_level
为replica
或logical
,并设置max_wal_senders
(最多同步工作进程数),max_replication_slots
(最大复制槽数),以及wal_sender_timeout
(超时时间)。 创建一个复制用户(在主节点上):
CREATE ROLE replica LOGIN REPLICATION ENCRYPTED PASSWORD 'password';
在从节点上配置
recovery.conf
(PostgreSQL 12之前版本)或者postgresql.conf
(从PostgreSQL 12开始),设置primary_conninfo
,指定连接到主节点的参数,例如:primary_conninfo = 'host=master_ip_address port=5432 user=replica password=password sslmode=prefer sslcompression=1'
- 在从节点上,重启PostgreSQL服务以应用配置。
关于要求强一致性(同步复制)还是可以接受弱一致性(异步复制),这取决于你的应用需求:
- 同步复制:确保数据在主节点提交后,在从节点上也已经提交,保证数据的强一致性,但会降低性能。
- 异步复制:数据在主节点提交后即可发送到从节点,不等待从节点确认接收,性能较好,但在故障发生时可能丢失数据。
你可以在postgresql.conf
中设置synchronous_commit
来控制是否为同步复制,或者在primary_conninfo
中使用sync_mode
参数来指定同步模式(如sync_mode='sync'
表示同步复制)。
示例配置:
synchronous_commit = on # 开启同步提交
primary_conninfo = 'host=master_ip_address port=5432 user=replica password=password sslmode=prefer sslcompression=1 sync_mode=sync'
请根据实际需求选择合适的复制模式。