0

0

postgresql同步事务为何性能下降_postgresqlcommit原理解析

冷炫風刃

冷炫風刃

发布时间:2025-11-25 20:12:06

|

247人浏览过

|

来源于php中文网

原创

PostgreSQL同步事务性能下降主要因WAL刷盘I/O开销大,每次commit需等待fsync完成。高并发下频繁刷盘导致延迟上升,尤其在机械硬盘或小事务场景更明显。默认synchronous_commit=on保障数据安全但增加延迟。可通过调整为synchronous_commit=off、启用组提交、使用SSD存储、增大wal_buffers及批量提交等手段优化,在数据安全与性能间取得平衡。

postgresql同步事务为何性能下降_postgresqlcommit原理解析

PostgreSQL 在处理同步事务时性能下降,通常与事务提交(commit)机制和数据持久化策略密切相关。理解 PostgreSQL 的 commit 原理,有助于分析性能瓶颈并优化系统表现。

PostgreSQL 事务提交的基本原理

PostgreSQL 使用预写式日志(Write-Ahead Logging, WAL)来保证事务的持久性和崩溃恢复能力。每次事务提交时,必须确保该事务的 WAL 记录已写入磁盘。这个过程是阻塞的,直到操作系统确认数据落盘,事务才能返回成功。

关键步骤包括:

  • 生成 WAL 日志:事务执行过程中产生的修改会先记录到 WAL 缓冲区。
  • WAL 刷盘(fsync):在事务提交时,PostgreSQL 调用操作系统接口(如 fsync)将 WAL 日志从内核缓冲区刷入物理存储。
  • 返回客户端确认:只有 WAL 确认落盘后,commit 才返回成功。

由于磁盘 I/O 特别是 fsync 操作耗时较长,高并发场景下频繁提交会导致明显的性能下降。

同步提交模式对性能的影响

PostgreSQL 默认使用同步提交(synchronous_commit = on),确保每个事务在返回客户端前已完成 WAL 落盘。虽然保障了数据安全,但代价是延迟增加。

Whimsical
Whimsical

Whimsical推出的AI思维导图工具

下载

常见影响因素:

  • 磁盘 I/O 性能:机械硬盘随机写性能差,成为 WAL 写入瓶颈。
  • 高并发小事务:大量短事务频繁调用 fsync,导致 I/O 队列积压。
  • WAL 文件段切换开销:每 16MB 切换一次 WAL 段,频繁切换可能引入额外延迟。

如何缓解同步事务的性能问题

在可接受范围内调整配置,可以显著提升提交性能:

  • 调整 synchronous_commit:设为 offlocal 可避免每次 commit 都等待 WAL 刷盘,但牺牲部分持久性。
  • 启用组提交(group commit):多个事务共享一次 fsync,需配合 wal_writer_delay 和 commit_delay 使用。
  • 使用高速存储:SSD 或 NVMe 显著降低 fsync 延迟。
  • 增大 wal_buffers:减少 WAL 日志写磁盘频率。
  • 批量提交事务:将多个操作合并为一个事务,减少 commit 次数。

总结

PostgreSQL 同步事务性能下降的核心在于 WAL 刷盘的 I/O 开销。commit 必须等待 fsync 完成,导致高并发下延迟上升。通过合理配置提交模式、优化存储性能和调整事务设计,可以在安全与性能之间取得平衡。

基本上就这些,关键是要根据业务对数据安全的要求,选择合适的提交策略。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1018

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

62

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

400

2025.12.29

postgresql常用命令
postgresql常用命令

postgresql常用命令psql、createdb、dropdb、createuser、dropuser、l、c、dt、d table_name、du、i file_name、e和q等。本专题为大家提供postgresql相关的文章、下载、课程内容,供大家免费下载体验。

158

2023.10.10

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

970

2023.11.02

postgresql常用命令有哪些
postgresql常用命令有哪些

postgresql常用命令psql、createdb、dropdb、createuser、dropuser、l、c、dt、d table_name、du、i file_name、e和q等。更详细的postgresql常用命令,大家可以访问下面的文章。

195

2023.11.16

postgresql常用命令介绍
postgresql常用命令介绍

postgresql常用命令有l、d、d5、di、ds、dv、df、dn、db、dg、dp、c、pset、show search_path、ALTER TABLE、INSERT INTO、UPDATE、DELETE FROM、SELECT等。想了解更多postgresql的相关内容,可以阅读本专题下面的文章。

267

2023.11.20

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

36

2026.01.14

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

14

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Rust 教程
Rust 教程

共28课时 | 4.4万人学习

PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.2万人学习

Git 教程
Git 教程

共21课时 | 2.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号