有关mysql查询缓存的内存碎片

发布时间:2019-11-17编辑:脚本学堂
本文介绍下,有关mysql查询缓存中内存碎片的相关知识,有需要的朋友,参考下吧。

说到mysql的查询缓存,先来熟悉下面三个选项:
query_cache_min_res_unit   查询缓存分配的最小块的大小(字节)
query_alloc_block_size  查询分析和执行过程中创建的对象分配的内存块大小
Qcache_free_blocks  内存自由块的多少,反映了内存碎片的情况

下面进行解析:
1,当执行数据库查询进行时,Mysql把查询结果保存在qurey cache中,但如果要保存的结果比较大,超过query_cache_min_res_unit的值 ,此时mysql将一边检索结果,一边
进行保存结果,所以,有时并不是把所有结果全部得到后再进行一次性保存,而是每次分配一块query_cache_min_res_unit 大小的内存空间保存结果集,使用完后,接着再分
配一个这样的块。如果还不不够,接着再分配一个块,依此类推,即有可能在一次查询中,mysql要进行多次内存分配的操作。

2,内存碎片的产生。
当一块分配的内存没有完全使用时,MySQL会把这块内存Trim掉,把没有使用的那部分归还以重复利用。
比如,第一次分配4KB,只用了3KB,剩1KB,第二次连续操作,分配4KB,用了2KB,剩2KB,这两次连续操作共剩下的1KB+2KB=3KB,不足以做个一个内存单元分配, 这时候,内
存碎片便产生了。

3,使用 flush query cache 可以消除碎片。

4,如果Qcache_free_blocks值过大,可能是query_cache_min_res_unit值过大,调小一些,即可改善

5,query_cache_min_res_unit的估计值:
(query_cache_size - Qcache_free_memory) / Qcache_queries_in_cache

就介绍这些吧,希望有助于大家理解与合理应用mysql的查询缓存与内存碎片。
脚本学堂,祝大家学习进步。