PostgreSQL 流复制参数 - synchronous_commit

文章目录

  • 一、单实例
    • [1、synchronous_commit = off](#1、synchronous_commit = off)
    • [2、synchronous_commit = on / local](#2、synchronous_commit = on / local)
  • 二、主从
    • [1、synchronous_commit = off](#1、synchronous_commit = off)
    • [2、synchronous_commit = local](#2、synchronous_commit = local)
    • [3、synchronous_commit = remote_write](#3、synchronous_commit = remote_write)
    • [4、synchronous_commit = on](#4、synchronous_commit = on)
    • [5、synchronous_commit = remote_apply](#5、synchronous_commit = remote_apply)

一、单实例

1、synchronous_commit = off

设置成off表示提交事务时不需等待相应WAL数据写入本地WAL日志文件即可向客户端返回成功。当数据库宕机时最新提交的少量事务可能丢失,但数据库重启后会认为这些事务异常中止。

设置成off能够提升数据库性能,因此对于数据准确性没有精确要求同时追求数据库性能的场景可以考虑设置成off。

2、synchronous_commit = on / local

单实例下设置成 on或local均表示提交事务时需等待相应WAL数据写入本地WAL日志文件后才向客户端返回成功。设置成on理论上事务是绝对安全的,但相对与off需要略微多一点额外的耗时。

二、主从

1、synchronous_commit = off

含义与单实例相同,表示提交事务时不需等待本地相应WAL数据写入本地WAL日志文件即可向客户端返回成功。

2、synchronous_commit = local

含义与单实例相同,表示提交事务时需等待相应WAL数据写入本地WAL日志文件后才向客户端返回成功,但是不关心从节点的情况。

3、synchronous_commit = remote_write

如果没有设置synchronous_standby_names,remote_write跟单实例下synchronous_commit=local含义相同

  如果设置了设置了synchronous_standby_names:

  当流复制主库提交事务时,需等待备库接收主库发送的WAL日志流并写入备节点操作系统缓存中,才向客户端返回成功,此时备库的WAL还在备库操作系统缓存中。

  除非一个事物提交之后,在standby节点WAL日志固化之前的wal_writer_delay(默认200毫秒)这个间隔内,同时发生这两个事件:

  1. 主节点磁盘故障导致数据损坏;

  2. standby节点操作系统发生宕机,才有可能造成数据丢失。

4、synchronous_commit = on

如果未设置synchronous_standby_names = on跟单实例下含义相同

  如果设置了synchronous_standby_names = on跟单实例下含义不同,此时表示流复制主库提交事务时,需等待备库接收主库发送的WAL日志流并写入WAL文件,也即主备的WAL日志同时落盘之后,之后才向客户端返回成功。

5、synchronous_commit = remote_apply

如果未设置synchronous_standby_names,remote_apply等同于on,跟单实例下含义相同。

  如果设置了synchronous_standby_names = on跟单实例下含义不同,表示流复制主库提交事务时 ,需等待备库完成相应的WAL日志的apply才向客户端返回成功。

  也就是说从数据需要接收主节点WAL日志,并且完成了WAL的"翻译"工作,主备数据完全一致的情况下才返回事务提交成功的标记。

相关推荐
是发财不是旺财16 小时前
Hermes 网关四层权限控制方案:让 AI Agent 安全地查数据库
数据库·安全·agent·openclaw·hermes
阿正的梦工坊16 小时前
【Rust】04-借用、引用与切片
java·数据库·rust
AOwhisky16 小时前
学习自测与解析:MySQL第五、六、七期核心知识点详解
运维·数据库·笔记·学习·mysql·云计算
阿标在干嘛16 小时前
政策平台的推送系统:消息队列、定时任务、AB测试的工程实践
服务器·数据库·ab测试
Upsy-Daisy16 小时前
Hermes Agent 学习笔记 02:安装、配置与第一次运行
java·前端·数据库
Tongpao_SSDHDD17 小时前
希捷酷鹰ST6000VX008实测解析:中小安防监控高性价比存储方案
大数据·数据库·人工智能
蓝鸟197417 小时前
Oracle超大DMP备份文件瘦身、日志精简、磁盘空间优化实战方案日志
数据库·oracle·数据库运维·生产运维实战·oracle避坑·磁盘空间优化·oracle日志清理
金融支付架构实战指南18 小时前
CQRS + 命令模式 + 事件驱动 + 数据库持久化
数据库·ddd·命令模式·领域驱动模型
sevenll0718 小时前
DocKit agentic MongoDB GUI 客户端 - 用自然语言和你的数据对话
数据库·mongodb·nosql·agent·桌面客户端
团象科技18 小时前
从一线实操案例拆解不同出海团队落地海外VPS运维独立站的路径细节
大数据·数据库·人工智能