MySQL优化相关查询指令

来源:互联网 发布:网易复权数据接口 编辑:程序博客网 时间:2024/05/16 15:15

http://www.yuansir-web.com/2011/10/20/mysql%E4%BC%98%E5%8C%96%E7%9B%B8%E5%85%B3%E6%9F%A5%E8%AF%A2%E6%8C%87%E4%BB%A4/


转载请注明: 转载自Yuansir-web菜鸟 | LAMP学习笔记

本文链接地址: MySQL优化相关查询指令

查看MySQL服务器配置信息
mysql> show variables;

查看MySQL服务器运行的各种状态值
mysql> show global status;

慢查询
mysql> show variables like ‘%slow%';
mysql> show global status like ‘%slow%';
分析慢查询日志,找出有问题的SQL语句,慢查询时间不宜设置过长,否则意义不大,最好在5秒以内,如果你需要微秒级别的慢查询,可以考虑给MySQL打补丁:http://www.percona.com/docs/wiki/release:start,记得找对应的版本。

连接数
经常会遇见”MySQL: ERROR 1040: Too many connections”的情况,一种是访问量确实很高,MySQL服务器抗不住,这个时候就要考虑增加从服务器分散读压力,另外一种情况是MySQL配置文件中max_connections值过小:
mysql> show variables like ‘max_connections';
mysql> show global status like ‘max_used_connections';
max_used_connections / max_connections * 100% = 99.6% (理想值 ≈ 85%)
最大连接数占上限连接数的85%左右,如果发现比例在10%以下,MySQL服务器连接数上限设置的过高了。

key_buffer_size
key_buffer_size是对MyISAM表性能影响最大的一个参数, 不过数据库中多为Innodb
mysql> show variables like ‘key_buffer_size';
mysql> show global status like ‘key_read%';
计算索引未命中缓存的概率:
key_cache_miss_rate = Key_reads / Key_read_requests * 100% =0.27%
key_cache_miss_rate在0.1%以下都很好(每1000个请求有一个直接读硬盘),如果key_cache_miss_rate在0.01%以下的话,key_buffer_size分配的过多,可以适当减少。

key_blocks_*参数
mysql> show global status like ‘key_blocks_u%';
Key_blocks_unused表示未使用的缓存簇(blocks)数,
Key_blocks_used表示曾经用到的最大的blocks数。
比较理想的设置:
Key_blocks_used / (Key_blocks_unused + Key_blocks_used) * 100% ≈ 80%

open table 的情况
mysql> show global status like ‘open%tables%';
Open_tables 表示打开表的数量,Opened_tables表示打开过的表数量,如果Opened_tables数量过大,说明配置中 table_cache(5.1.3之后这个值叫做table_open_cache)值可能太小,我们查询一下服务器table_cache值
mysql> show variables like ‘table_cache';
Open_tables / Opened_tables * 100% =69% 理想值 (>= 85%)
Open_tables / table_cache * 100% = 100% 理想值 (<= 95%)

进程使用情况
mysql> show global status like ‘Thread%';
如果我们在MySQL服务器配置文件中设置了thread_cache_size,当客户端断开之后,服务器处理此客户的线程将会缓存起来以响应下一个客户而不是销毁(前提是缓存数未达上限)。Threads_created表示创建过的线程数,如果发现Threads_created值过大的话,表明 MySQL服务器一直在创建线程,这也是比较耗资源,可以适当增加配置文件中thread_cache_size值,查询服务器 thread_cache_size配置:
mysql> show variables like ‘thread_cache_size';

查询缓存(query cache)
mysql> show variables like ‘query_cache%';
mysql> show global status like ‘qcache%';
Qcache_free_blocks:缓存中相邻内存块的个数。数目大说明可能有碎片。FLUSH QUERY CACHE会对缓存中的碎片进行整理,从而得到一个空闲块。
Qcache_free_memory:缓存中的空闲内存。
Qcache_hits:每次查询在缓存中命中时就增大
Qcache_inserts:每次插入一个查询时就增大。命中次数除以插入次数就是不中比率。
Qcache_lowmem_prunes:缓存出现内存不足并且必须要进行清理以便为更多查询提供空间的次数。这个数字最好长时间来看;如果这个数字在不断增长,就表示可能碎片非常严重,或者内存很少。
Qcache_not_cached:不适合进行缓存的查询的数量,通常是由于这些查询不是 SELECT 语句或者用了now()之类的函数。
Qcache_queries_in_cache:当前缓存的查询(和响应)的数量。
Qcache_total_blocks:缓存中块的数量。

转载请注明: 转载自Yuansir-web菜鸟 | LAMP学习笔记

本文链接地址: MySQL优化相关查询指令


0 0