MYSQL面试必问—INSERT BUFFER

​INSERT BUFFER即合并插入缓存,从MySQL 5.1.X版本(innodb 1.0.x)开始引入Changebuffer,是INSERT BUFFER升级版,不仅包括INSERT BUFFER,还包括UPDATE BUFFER、DELETE BUFFER、PURGE BUFFER。

 

我们可以通过show engine innodb status看到INSERT BUFFER信息。

一条命令解读InnoDB存储引擎—show engine innodb status

 

Insert BUFFER适用对象:非唯一的辅助索引

Insert BUFFER功能:使随机io变顺序io,提升性能

 

Mysql5.6(innodb 1.2.x)版本以后引入innodb_change_buffer_max_size参数,控制最大内存使用数量,默认25,表示最多使用1/4的缓冲池内存空间,该参数最大有效值为50。

(root@localhost)>show global variables like '%change_buffer%';+-------------------------------+-------+| Variable_name                 | Value |+-------------------------------+-------+|innodb_change_buffer_max_size | 25    || innodb_change_buffering       | all   |+-------------------------------+-------+

 

Create table test1(Id int auto_increment,Name varchar(20),Primary key(id),Key(name))engine =innodb;Select * from test1;Id     name1      a2      c...10000    b...100000    d...1000000    eInsert into test1(name) valuse(’c’);Insert into test1(name) valuse(’d’);1000001    c1000002    d

首先了解下相关Thread

 

INSERT BUFFER的频率

可能,1秒,需要判断前1秒的IO次数是否小于5,如果小于5则认为当前压力较小,可以执行合并插入操作。

总是,每10秒,合并最多5个插入缓冲

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值