查询缓存机制是否打开
show global variables like '%query_cache_type';
默认不打开缓存机制:
设置查询缓存机制
查询缓存机制可以设置为OFF(0)、ON(1)和DEMAND(2)。DEMAND表示只有在查询语句中明确写明SQL_CACHE的语句才会放入查询缓存。 设置方法:在 mysql配置文件的mysqld中设置,如: query_cache_type = 1
当设置查询缓存机制为 DEMAND 时,对于确定要使用查询缓存的语句:
select SQL_CACHE * from testdb where id = 1;
监控查询缓存的命中率
show status like '%Qcache%';
Qcache_free_blocks :表示查询缓存中还有多少剩余的blocks,如果该值显示较大,则说明查询缓存中的内存碎片过多了,可能在一定的时间进行整理。
Qcache_free_memory :查询缓存的内存大小,通过这个参数可以很清晰的知道当前系统的查询内存是否够用,是多了,还是不够用,DBA可以根据实际情况做出调整。
Qcache_free_memory :查询缓存的内存大小,通过这个参数可以很清晰的知道当前系统的查询内存是否够用,是多了,还是不够用,DBA可以根据实际情况做出调整。
Qcache_inserts:表示多少次未命中然后插入,意思是新来的SQL请求在缓存中未找到,不得不执行查询处理,执行查询处理后把结果insert到查询缓存中。这样的情况的次数越多,表示查询缓存应用到的比较少,效果也就不理想。当然系统刚启动后,查询缓存是空的,这很正常。
Qcache_lowmem_prunes :该参数记录有多少条查询因为内存不足而被移除出查询缓存。通过这个值,用户可以适当的调整缓存大小。
Qcache_not_cached :表示因为query_cache_type的设置而没有被缓存的查询数量。
Qcache_queries_in_cache :当前缓存中缓存的查询数量。
Qcache_total_blocks:当前缓存的block数量。