IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

标签:Group Commit

共 3 篇相关文章

IT 累计浏览 2,755

MySQL数据库InnoDB存储引擎的Group Commit(二)

这篇讲的是MySQL InnoDB存储引擎如何通过Group Commit技术来优化事务提交性能,特别是二进制日志(binlog)刷新与事务提交之间的串行化瓶颈问题。 作者兴奋地指出,Percona Server在其5.5.18-23.0版本中,已经优雅地实现了这一关键优化。其核心方案并非采用常见的“曲线救国”式workaround,而是直接移植了MariaDB数据库中被验证为高效的Group Commit实现。这意味着,多个并发事务在提交时可以被分组,一次性将日志刷盘,从而大幅减少磁盘I/O次数,显著提升高并发场景下的写入吞吐量。 这个实现的巧妙之处在于它以最“正统”的方式解决了历史难题。对于依赖Percona Server进行高性能数据库运维或开发的团队来说,这个版本的发布意味着一个长期以来的性能瓶颈被正式移除,为系统带来了切实的性能收益。

IT 累计浏览 2,632

MySQL数据库InnoDB存储引擎的Group Commit(一)

这篇讲的是MySQL InnoDB存储引擎中一个经典的性能优化问题——Group Commit。文章没有提出新观点,而是基于Kristian Nielsen的四篇深度分析文章,对这个“由来已久”的问题做了一次清晰的梳理。 作者从Group Commit的定义出发,解释了它为什么在InnoDB中如此关键。简单来说,Group Commit是一项旨在提高事务提交性能的技术,通过将多个并发事务的提交操作合并为一次磁盘刷新(fsync),从而显著减少I/O开销。文章点出了它曾引发广泛关注的原因:在早期版本中,这个机制存在缺陷,可能导致严重的性能瓶颈。 目前,这个问题已经得到妥善解决。文章概述了修复方案的核心思路,帮助读者理解InnoDB如何通过改进的Group Commit机制,保障了高并发事务提交时的效率与可靠性。如果你对MySQL内部机制和性能优化的演进感兴趣,这篇文章提供了一个不错的入门总结。

IT 累计浏览 2,103

MariaDB与Percona XtraDB的Group Commit实现原理分析

这篇从MySQL InnoDB存储引擎一个长期存在的bug切入:开启binlog后,由于要保证事务日志与mysqlbinlog的顺序一致性,导致无法进行group commit,这严重影响了高并发写入性能。文章详细剖析了MariaDB与Percona XtraDB这两个主流分支是如何解决这个“老大难”问题的。 核心对比在于它们各自的实现思路。MariaDB通过引入逻辑时钟(lc)来统一排序binlog与InnoDB日志,巧妙地将group commit的决策提前到binlog阶段完成,打破了原本的依赖链。而Percona XtraDB则采取了更为集中的“协调者”模式,在存储引擎层进行统一协调,确保两阶段提交的原子性与性能。两者都通过精巧的设计,在无需改变原有复制逻辑的前提下,恢复了group commit的能力。 文章没有停留在原理对比,还结合代码路径和关键变量,点明了不同实现对复杂度和性能的权衡。对于想深入理解MySQL事务提交内部机制,或者在面临高并发写入瓶颈时做技术选型的读者来说,这篇对底层实现的拆解提供了扎实的参考。