POSTGRESQL 建立主从节点全流程 与 要不要强一致的问题
warning:
这篇文章距离上次修改已过428天,其中的内容可能已经有所变动。
在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'请根据实际需求选择合适的复制模式。
评论已关闭