目录
查询MySQL的缓存相关信息,一般我们用两个命令:
show variables like '%query_cache%';
show status like '%qcache%';
一、查看缓存配置
查看缓存配置的相关的系统变量变量,返回给我们服务器缓存的配置参数。
举个栗子:打开数据库,新建查询输入:show variables like '%query_cache%';
其中 :
①have_query_cache表示是否支持查询缓存,YES表示支持;
②query_cache_type表示缓存类型,OFF表示关闭查询缓存,ON表示开启,DEMAND表示用户自定义查询缓存;
如:开启或禁用查询缓存
SET GLOBAL query_cache_type = ON;
③query_cache_limit表示支持的最大单条查询sql数据量;
如:设置单个查询的最大缓存给1MB,超出范围则不缓存
SET GLOBAL query_cache_limit = 1048576;
④query_cache_min_res_unit表示查询缓存最小单位;
如:修改查询缓存最小单位为4KB:
SET GLOBAL query_cache_min_res_unit = 4096;
⑤query_cache_size表示查询缓存空间大小;
如:将数据库缓存大小修改为16MB
SET GLOBAL query_cache_size = 16777216;
⑥query_cache_wlock_invalidate表示查询缓存是否支持写锁,OFF表示不支持,即 读取数据不考虑写锁,ON表示支持,即读取数据会被写锁阻塞;
注意:以上这些操作也是一次性有效的,要想MySQL重启后永久生效,需要去服务器中找到MySQL配置文件my.cnf 或my.ini修改内容:
在 **[mysqId]**下面加上自己定义的配置信息
query_cache_size = 16777216 # 16MB query_cache_type = ON query_cache_limit = 1048576 # 1MB query_cache_min_res_unit = 4096 # 4KB
保存并重启mysql容器:docker restart mysql容器id
接下来再返回数据库执行show variables like '%query_cache%'; 查看此时的缓存配置:
已之前配置对比,配置成功生效!
二、查看缓存信息
查看缓存运行状态与相关的动态运行信息,其返回值可能帮助我们了解缓存的工作效果。
举个栗子:依旧在查询窗口,输入:show status like '%Qcache%';
其中:
①Qcache_free_blocks表示已分配内存块中空闲块数量;
②Qcache_free_memory表示缓存空闲空间大小;
③Qcache_hits表示缓存命次数;
④Qcache_inserts表示缓存未命中时,数据写入缓存次数;
⑤Qcache_lowmem_prunes表示缓存修剪次数,缓存满时,会使用LRU算法移除最久未被使用缓存,此值较大,说明缓存空间太小;
⑥Qcache_not_cached表示没有被缓存的查询sql数量;
⑦Qcache_queries_in_cache表示缓存查询语句数量;
⑧Qcache_total_blocks 表示当前查询缓存占用的内存块数量;
原理与上述同理。