怎么理解MarriDB/MySQL的binlog group commit技术


这篇文章主要介绍“怎么理解MarriDB/MySQL的binlog group commit技术”,在日常操作中,相信很多人在怎么理解MarriDB/MySQL的binlog group commit技术问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么理解MarriDB/MySQL的binlog group commit开发云主机域名技术”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
我们知道,操作系统使用页面缓存机制来填补内存访问速度和磁盘访问速度之间的差距。通常情况下,对磁盘文件的写都会先写入到页面缓存中,
然后由操作系统来决定何时将修改过的脏页刷新到磁盘上。如果想确保修改已经持久写到了磁盘,必须调用fsync或fdatasync。在关系数据库中,
为了满足ACID中的持久化属性,也就是说事务提交并成功返回给客户端之后,必须保证该事务的所有修改不能丢。无论是在数据库程序崩溃的情况下,
还是在数据库所在的服务器发生宕机或断电的情况下,都必须保证数据不能丢,这就要求数据库在事务提交过程中调用fsync或fdatasync将数据持久化
到磁盘。fsync是一个昂贵的系统调用,对于普通的磁盘,每秒只能完成几百次的fsync操作,很明显,fsync将会限制每秒提交的事务数,成为关系
数据库的瓶颈。
对于MarriDB/MySQL来说,这种情况变得更加糟糕。在开启binlog的情况下,为了保证主库和从库之间数据的一致性,MarriDB/MySQL使用了事务的
两阶段提交协议。在这种情况下,为了满足数据的持久化需求,一个事务的提交最多会导致3次fsync操作。
为了提高MarriDB/MySQL在开启binlog的情况下单位时间内的事务提交数,就必须减少每个事务提交过程中导致的fsync的调用次数。MarriDB从5.3版本开始,
引入了binlog group commit技术来解决这个问题。MySQL从5.6版本开始也加入了binlog group commit技术。
binlog group commit的基本思想是多个并发提交的事务之间共用一次fsync操作来实现事务对binlog修改的持久化。
到此,关于“怎么理解MarriDB/MySQL的binlog group commit技术”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注开发云网站,小编会继续努力为大家带来更多实用的文章!

相关推荐: Centos部署MySQL 5.7

服务器一台,下载我提供的源码包,并上传至服务器。当执行初始化操作后,在返回信息的最后一行,将显示着MySQL数据库root用户的密码,也有可能不显示,那就说明root用户没有密码,我这里显示的密码如下(此密码需要先复制到一个文本上,一会修改密码需要用到,如果此…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 06/27 22:04
下一篇 06/27 22:05

相关推荐