欢迎光临
我们一直在努力

【Mysql】JDB2导致磁盘io使用率高 导致mysql延迟过高

参考连接:http://www.bubuko.com/infodetail-971804.html

背景:某项目slave数据库的延迟非常大

  1. 结合上iostat中 wsec/s 较大的数值,基本可以确定IO高负载的元凶是redo log的flush,而不是data page的flush

  1. 查看innodb log buffer状态

    1. mysql> show global status where variable_name in(‘Innodb_log_waits’,‘Innodb_buffer_pool_wait_free’);
    2. +++
    3. | Variable_name | Value |
    4. +++
    5. | Innodb_buffer_pool_wait_free | 0 |
    6. | Innodb_log_waits | 2560 | ####log buffer过小导致写日志等待数。单位是次。
    7. +++

加大log_buffer_pool与innodb_log_file_size的值,重启数据库,发现iowait降低,slave开始下降!

总结:优化io过高的几种原因:
1.是否是buffer pool过小导致的              参考文章:叶金荣–是什么导致磁盘io过高 http://mp.weixin.qq.com/s/sAGFo-h2GCBhad1r1cEWTg
2.是否是sql导致的
3.innodb_io_captiy对io稳定性的影响     http://blog.itpub.net/29096438/viewspace-2134208/
4.其它系统原因


赞(0)
【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。