性能调优之mysql通过status性能优化 2

释放双眼,带上耳机,听听看~!

三、key_buffer_size

key_buffer_size是对myisam表性能影响最大的一个参数,下面一台以myisam为主要存储引擎服务器的配置:

mysql> show variables like 'key_buffer_size';

+—————–+————+

| variable_name    | value       |

+—————–+————+

| key_buffer_size | 536870912 |

+—————–+————+

分配了512mb内存给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%

四、临时表

mysql> show global status like 'created_tmp%';

+————————-+———+

| variable_name            | value    |

+————————-+———+

| created_tmp_disk_tables | 21197    |

| created_tmp_files        | 58       |

| created_tmp_tables       | 1771587 |

+————————-+———+

每次创建临时表,created_tmp_tables增加,如果是在磁盘上创建临时表,created_tmp_disk_tables也增加,created_tmp_files表示mysql服务创建的临时文件文件数,比较理想的配置是:

created_tmp_disk_tables / created_tmp_tables * 100%< = 25%比如上面的服务器created_tmp_disk_tables / created_tmp_tables * 100% = 1.20%,应该相当好了。我们再看一下mysql服务器对临时表的配置:

mysql> show variables where variable_name in ('tmp_table_size', 'max_heap_table_size');

+———————+———–+

| variable_name        | value      |

+———————+———–+

| max_heap_table_size | 268435456 |

| tmp_table_size       | 536870912 |

+———————+———–+

只有256mb以下的临时表才能全部放内存,超过的就会用到硬盘临时表。

给TA打赏
共{{data.count}}人
人已打赏
安全运维

OpenSSH-8.7p1离线升级修复安全漏洞

2021-10-23 10:13:25

安全运维

设计模式的设计原则

2021-12-12 17:36:11

个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索