MYSQLchangebuffer的原理说明

这篇文章主要讲解了“MySQL change buffer的原理说明”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MYSQL change buffer的原理说明”吧!

专业成都网站建设公司,做排名好的好网站,排在同行前面,为您带来客户和效益!创新互联建站为您提供成都网站建设,五站合一网站设计制作,服务好的网站设计公司,网站建设、网站设计负责任的成都网站制作公司!

关于MYSQL 的change buffer 的说一说,为何,因为它可以加速你的写操作,意思就是 insert  update delete 等操作,尤其是你的表有一堆索引的情况下,那必须要进行特殊的设置。

可能马上有一个声音,为什么是表有一堆索引的情况下,才要有特殊的设置。

1 索引与表是紧密的关系,插入,更新,删除一条记录,就会触发与表有关系的索引的操作,你可以将他们看做一个事务,如果其中有任何一个对索引的操作失败,则你的数据对表的操作也应该会失败。

2 对于表附加的索引的操作必然影响对源表的数据的操作速度,而DML操作会影响数据的读取和事务隔离性相关的性能,然后引起连锁反应,表插入的,更改的,删除的,慢了,则表的SELECT 的性能也必然受到影响。

3 当对表执行插入、更新和删除操作时,索引(非聚集索引)列的值通常是无序的,这需要大量的I/O来更新辅助索引。当相关页不在缓冲池中时,更改缓冲区将更改缓存到索引,从而通过不立即从磁盘读入页来避免昂贵的I/O操作。当页面加载到缓冲池中时,将合并已缓存的更改,然后将更新后的页面刷新到磁盘。

带来的好处,如果MYSQL 承担大量的DML操作,则change buffer是必不可少的,他的存在就是尽量减小I/O的消耗,通过内存进行数据的合并操作,将多次操作操作尽量变为少量的I/O操作。带来的坏处,就是change buffer 会使用innodb_buffer的空间,所以如果你内存少,那就....... 默哀3分钟。

说道这个东西,那自然必须要在MY.CNF 中调整一下参数配置。

具体有两个参数

innodb_change_buffering  

这个参数决定了你的change buffer的用途,你是要吃咸的还是甜的,都在这里面了。具体的选择项

none

inserts

deletes

changes

purges

all

innodb_change_buffer_max_size

另一个选择项是对 buffer_pool 中的内存进行百分比的设置,默认是 25% 最大你可以设置 50% 

innodb_change_buffering_debug

对于change buffer 如果造成问题,我们也需要第一时间从 ERRORLOG 汇总获知,所以建议至少设置为 1

下面是MYSQL 不关于这部分的代码(有时间还真的好好看看C++,要不看代码属于白痴的水平),

1  UNIV_PAGE_SIZE  是 数据页的大小

2  buf_pool_get_curr_size 是 当前的 innodb_buffer_pool 的大小

最后最大的设置得到应该是以页面大小为单位的块的百分比。

MYSQL change buffer的原理说明

感谢各位的阅读,以上就是“MYSQL change buffer的原理说明”的内容了,经过本文的学习后,相信大家对MYSQL change buffer的原理说明这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!


分享标题:MYSQLchangebuffer的原理说明
网页URL:http://myzitong.com/article/pohpss.html