【MySQL】了解并操作MySQL的缓存配置与信息

目录

一、查看缓存配置

二、查看缓存信息


查询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.cnfmy.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 表示当前查询缓存占用的内存块数量;

原理与上述同理。

相关推荐
卡兰芙的微笑8 分钟前
get_property --Cmakelist之中
前端·数据库·编辑器
Z_W_H_19 分钟前
【PostgreSQL】安装及使用(Navicat/Arcgis),连接(C#)
数据库·postgresql
豆姐姐27 分钟前
金九银十,分享一波用例设计、数据库、编程笔试题!
自动化测试·数据库·测试用例·软件测试面试
计算机程序设计开发29 分钟前
计算机毕业设计公交站点线路查询网站登录注册搜索站点线路车次/springboot/javaWEB/J2EE/MYSQL数据库/vue前后分离小程序
数据库·vue.js·spring boot·课程设计·计算机毕业设计
waterHBO1 小时前
ER 图 Entity-Relationship (ER) diagram 101 电子商城 数据库设计
数据库
青云交1 小时前
大数据新视界 --大数据大厂之Kubernetes与大数据:容器化部署的最佳实践
数据库·kubernetes·容器编排·资源管理·大数据处理·扩展性、故障恢复·存储持久化·监控、日志管理、性能提升
liangbm32 小时前
MATLAB系列07:输入/输入函数
开发语言·数据库·笔记·matlab·函数·自定义函数·matlab函数
skate2 小时前
达梦disql支持上翻历史命令-安装rlwrap
数据库
慕容潇湘2 小时前
Oracle事物
数据库·oracle
hillstream32 小时前
oracle中NUMBER(1,0)的字段如何映射到c#中
数据库·oracle·c#