change buffer官方说明: https://dev.mysql.com/doc/refman/5.7/en/innodb-change-buffer.html
change buffer官方解答: https://dev.mysql.com/doc/refman/5.7/en/faqs-innodb-change-buffer.html
设计背景:
与聚集索引不同,二级索引通常是非唯一的,像delete和update操作的二级索引树中通常都是顺序相对随机不相邻的索引页,
这样会照成大量随机I/O
工作机制:
DML(insert,update,delete)操作使用到的二级索引页如果不在buffer pool中,就把它缓存到buffer pool的change buffer中。后续再进行合并操作,批量写回disk( master thread在服务器空闲时和slow shutdown期间会合并缓冲更改)。可避免大量随机I/O
注:change buffer不支持descending index,Clustered indexes,full-text indexes,spatial indexes
控制参数:
innodb_change_buffering :change buffer缓存级别有
innodb_change_buffering values include:
all 默认开启
The default value: buffer inserts, delete-marking operations, and purges.
none
Do not buffer any operations.
inserts
Buffer insert operations.
deletes
Buffer delete-marking operations.
changes (其实update操作就是做的 inserts and delete-marking)
Buffer both inserts and delete-marking operations.
purges
Buffer physical deletion operations that happen in the background.
innodb_change_buffer_max_size:change buffer是buffer pool中一块区域,5.6版本后默认大小是buffer pool的25%,参数
innodb_change_buffer_max_size
控制。
注:在内存中, change buffer占用buffer pool的一部分。在磁盘上, change buffer是system tablespace的一部分,当数据库服务器关闭时,索引更改将在其中缓冲。
使用监控
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14 |
mysql> SHOW ENGINE INNODB STATUS\G
|
change buffer 占用率
|
1
2
3
4
5
6
7
8
9
10 |
mysql>
|
原文链接: http://blog.itpub.net/25583515/viewspace-2727658/
编辑推荐:
- mysql慢查询03-01
- Innodb特性之change buffer03-01
- 实战分享 | 你知道这个死锁是怎么产生的吗?03-01
- 啥?你忘记了Mysql密码?03-01
- mysqldump中skip-tz-utc参数介绍03-01
- 14.5.1 Innodb 的锁03-01
- 即将写入MySQL源码的官方bug解决之路03-01
- 如何应对事关业务生死的数据泄露和删改?03-01
相关推荐
-
雷神推出 MIX PRO II 迷你主机:基于 Ultra 200H,玻璃上盖 + ARGB 灯效
2 月 9 日消息,雷神 (THUNDEROBOT) 现已宣布推出基于英
-
制造商 Musnap 推出彩色墨水屏电纸书 Ocean C:支持手写笔、第三方安卓应用
2 月 10 日消息,制造商 Musnap 现已在海外推出一款 Oce
