当前位置: 首页 > news >正文

mysql5.6之key_buffer_size优化设置

key_buffer_size指定索引缓冲区的大小,它决定索引处理的速度,尤其是索引读的速度。通过检查状态值Key_read_requests和Key_reads,可以知道key_buffer_size设置是否合理。比例key_reads /key_read_requests应该尽可能的低,至少是1:100,1:1000更好(上述状态值可以使用SHOW STATUS LIKE ‘key_read%'获得)。

key_buffer_size只对MyISAM表起作用。即使你不使用MyISAM表,但是内部的临时磁盘表是MyISAM表,也要使用该值。可以使用检查状态值created_tmp_disk_tables得知详情。

对于1G内存的机器,如果不使用MyISAM表,推荐值是16M(8-64M)


提升性能的建议:

1.如果opened_tables太大,应该把my.cnf中的table_cache变大

2.如果Key_reads太大,则应该把my.cnf中key_buffer_size变大.可以用Key_reads/Key_read_requests计算出cache失败率

3.如果Handler_read_rnd太大,则你写的SQL语句里很多查询都是要扫描整个表,而没有发挥键的作用

4.如果Threads_created太大,就要增加my.cnf中thread_cache_size的值.可以用Threads_created/Connections计算cache命中率

5.如果Created_tmp_disk_tables太大,就要增加my.cnf中tmp_table_size的值,用基于内存的临时表代替基于磁盘的 


mysql> show variables like 'key_buffer_size';  


+-----------------+------------+  


| Variable_name | Value |  


+-----------------+------------+  


| key_buffer_size | 536870912 |  


+-----------------+------------+  

分配了512MB内存给mysql key_buffer_size,我们再看一下key_buffer_size的使用情况:

mysql> show global status like 'key_read%';  


+------------------------+-------------+  


| Variable_name | Value |  


+------------------------+-------------+  


| Key_read_requests | 27813678764 |  


| Key_reads | 6798830 |  


+------------------------+-------------+  


 一共有27813678764个索引读取请求,有6798830个请求在内存中没有找到直接从硬盘读取索引,计算索引未命中缓存的概率:

key_cache_miss_rate = Key_reads / Key_read_requests * 100%

比如上面的数据,key_cache_miss_rate为0.0244%,4000个索引读取请求才有一个直接读硬盘,已经很BT了,key_cache_miss_rate在0.1%以下都很好(每1000个请求有一个直接读硬盘),如果key_cache_miss_rate在0.01%以下的话,key_buffer_size分配的过多,可以适当减少。


MySQL服务器还提供了key_blocks_*参数:

mysql> show global status like 'key_blocks_u%';  


+------------------------+-------------+  


| Variable_name | Value |  


+------------------------+-------------+  


| Key_blocks_unused | 0 |  


| Key_blocks_used | 413543 |  


+------------------------+-------------+  

Key_blocks_unused表示未使用的缓存簇(blocks)数,Key_blocks_used表示曾经用到的最大的blocks数,比如这台服务器,所有的缓存都用到了,要么增加key_buffer_size,要么就是过渡索引了,把缓存占满了。比较理想的设置:

Key_blocks_used / (Key_blocks_unused + Key_blocks_used) * 100% ≈ 80%


参考资料:https://yq.aliyun.com/ziliao/125858



 本文转自 wjw555 51CTO博客,原文链接:http://blog.51cto.com/wujianwei/1969471

相关文章:

  • 使用yum安装MariaDB
  • Oracle Goldengate Director软件截面图
  • Spring4-自动装配Beans-按属性名称自动装配
  • Office 365管理员快速上手手册
  • centos 系统管理维护指南
  • phpcms v9 添加内容出现500错误
  • ElasticSearch vs 关系型数据库
  • 【Kafka源码】broker被选为controller之后的连锁反应
  • 极速理解设计模式系列:14.轻量级模式(Flyweight Pattern)
  • Resin HTTPS 安装指南
  • Solr 整合
  • Android Framework 记录之二
  • 在窗体中添加标签Label、Icon图标
  • MultiRow发现之旅(三)- 模板管理器和Table
  • 利用JS实现的根据经纬度计算地球上两点之间的距离
  • [case10]使用RSQL实现端到端的动态查询
  • ES6 ...操作符
  • extjs4学习之配置
  • javascript 总结(常用工具类的封装)
  • JavaScript设计模式与开发实践系列之策略模式
  • MYSQL 的 IF 函数
  • Python学习笔记 字符串拼接
  • Redis学习笔记 - pipline(流水线、管道)
  • Terraform入门 - 3. 变更基础设施
  • 构造函数(constructor)与原型链(prototype)关系
  • 世界上最简单的无等待算法(getAndIncrement)
  • 原生JS动态加载JS、CSS文件及代码脚本
  • LevelDB 入门 —— 全面了解 LevelDB 的功能特性
  • mysql面试题分组并合并列
  • 整理一些计算机基础知识!
  • ​Kaggle X光肺炎检测比赛第二名方案解析 | CVPR 2020 Workshop
  • ​LeetCode解法汇总2182. 构造限制重复的字符串
  • ​VRRP 虚拟路由冗余协议(华为)
  • ​云纳万物 · 数皆有言|2021 七牛云战略发布会启幕,邀您赴约
  • #使用清华镜像源 安装/更新 指定版本tensorflow
  • %3cli%3e连接html页面,html+canvas实现屏幕截取
  • %3cscript放入php,跟bWAPP学WEB安全(PHP代码)--XSS跨站脚本攻击
  • (4)通过调用hadoop的java api实现本地文件上传到hadoop文件系统上
  • (分类)KNN算法- 参数调优
  • (教学思路 C#之类三)方法参数类型(ref、out、parmas)
  • (亲测)设​置​m​y​e​c​l​i​p​s​e​打​开​默​认​工​作​空​间...
  • (状压dp)uva 10817 Headmaster's Headache
  • .net core 6 集成和使用 mongodb
  • .net 反编译_.net反编译的相关问题
  • .net 使用$.ajax实现从前台调用后台方法(包含静态方法和非静态方法调用)
  • .NET 指南:抽象化实现的基类
  • .net操作Excel出错解决
  • /etc/sudoers (root权限管理)
  • @AliasFor注解
  • [ 云计算 | AWS ] 对比分析:Amazon SNS 与 SQS 消息服务的异同与选择
  • [1127]图形打印 sdutOJ
  • [2019.3.20]BZOJ4573 [Zjoi2016]大森林
  • [BUUCTF]-Reverse:reverse3解析
  • [c#基础]值类型和引用类型的Equals,==的区别
  • [C++]拼图游戏