0

0

mysql如何处理由于磁盘IO慢导致的事务提交延迟_mysql持久化调优

P粉602998670

P粉602998670

发布时间:2026-03-16 14:28:52

|

523人浏览过

|

来源于php中文网

原创

确认磁盘IO拖慢:strace抓卡住线程看是否停在fsync(3),或查INNODB STATUS中Log sequence与Log flushed差距是否持续拉大;iostat -x 1观察await>20ms且%util≈100%。

mysql如何处理由于磁盘io慢导致的事务提交延迟_mysql持久化调优

事务提交卡在 fsync 上,怎么确认是磁盘 IO 拖慢的?

MySQL 提交事务时卡住,最直接的线索就是 innodb_flush_log_at_trx_commit=1(默认值)下,每次 COMMIT 都会触发一次 fsyncib_logfile。如果磁盘慢,fsync 就成瓶颈。

验证方法很简单:用 strace 抓一个正在卡住的 mysqld 线程,看它是不是停在 fsync(3) 调用上;或者查 SHOW ENGINE INNODB STATUS 里的 LOG 部分,观察 Log sequence numberLog flushed up to 差距是否持续拉大。

  • pt-ioprofileiostat -x 1 查看 %utilawaitawait > 20ms%util ≈ 100% 基本坐实磁盘瓶颈
  • 别只看 SELECT 延迟——写密集场景下,COMMIT 才是真瓶颈,监控要盯住 innodb_os_log_pending_fsyncs 这个状态变量
  • 云盘(如 AWS gp3、阿里云 ESSD)要注意吞吐和 IOPS 是否被配额限制,iotop -p $(pgrep mysqld) 可看到实际发出的写请求大小和频率

innodb_flush_log_at_trx_commit 改成 0 或 2 真的能提速?风险在哪?

能提速,但不是“随便改”。这个参数控制的是 redo log 刷盘时机,直接影响持久性语义:

  • 0:每秒刷一次 log buffer 到文件,事务提交不刷盘 → 最快,但崩溃最多丢 1 秒数据
  • 2:事务提交只写入 OS page cache,不 fsync → 通常比 1 快 3–10 倍,崩溃仅在 OS 崩溃时丢数据(MySQL 进程挂不影响)
  • 1:严格 ACID,但代价是每次 COMMITfsync

线上调成 2 是常见折中方案,但注意:sync_binlog 如果也设为 01000,主从一致性可能出问题;若开启 GTID + 半同步,2 仍可满足大多数业务的可靠性要求。

社研通
社研通

文科研究生的学术加速器

下载

除了改参数,还有哪些 IO 层面的硬优化手段?

参数调优只是表层,IO 效率取决于硬件路径是否通畅:

  • 确保 innodb_log_file_size 足够大(建议单个 ≥ 1G),避免频繁 checkpoint 导致 log 文件循环写放大
  • redo log 文件必须放在独立物理盘(或至少独立 LVM 逻辑卷),千万别和 datadir 共用同一块 SSD/NVMe
  • 禁用 ext4 的 barrier=1(已在较新内核默认关闭),但务必确认文件系统挂载用了 data=ordered(默认)而非 data=writeback
  • MySQL 8.0+ 可启用 innodb_redo_log_capacity 动态调大总 redo 容量,减少日志归档压力

为什么 SSD 也卡?可能是 log_buffer 太小或日志写太碎

即使上了 NVMe,如果应用高频提交小事务(比如单行 INSERT + COMMIT),log buffer 写满快、fsync 触发频繁,依然会压垮设备 IOPS。

  • 检查 innodb_log_buffer_size 是否过小(默认 16M,高并发写建议 ≥ 64M)
  • perf record -e block:block_rq_issue,block:block_rq_complete -p $(pgrep mysqld) 看单次 fsync 对应多少 KB 的底层 IO 请求,若平均
  • 业务层尽量合并事务(比如批量 INSERT 后再 COMMIT),比调参数更治本

磁盘 IO 慢从来不是孤立问题,它把应用模式、MySQL 参数、文件系统行为、硬件特性全串在一起。调一个 fsync 相关参数前,先搞清你到底在牺牲什么,又换来了什么——否则很可能刚压下去延迟,又冒出主从延迟或崩溃恢复失败。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

686

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

534

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

287

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

520

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

267

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

542

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

668

2023.08.14

C++多线程并发控制与线程安全设计实践
C++多线程并发控制与线程安全设计实践

本专题围绕 C++ 在高性能系统开发中的并发控制技术展开,系统讲解多线程编程模型与线程安全设计方法。内容包括互斥锁、读写锁、条件变量、原子操作以及线程池实现机制,同时结合实际案例分析并发竞争、死锁避免与性能优化策略。通过实践讲解,帮助开发者掌握构建稳定高效并发系统的关键技术。

4

2026.03.16

热门下载

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

精品课程

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

共48课时 | 2.6万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 856人学习

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

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