当前位置: 首页 > article >正文

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

原理与上述同理。 


http://www.kler.cn/a/301727.html

相关文章:

  • 计算机视觉 1-8章 (硕士)
  • 开源共建 | 长安链开发常见问题及规避
  • 传奇996_24——变量lua
  • 加速 AI 创新:引入 Elastic AI 生态系统
  • sqli-labs靶场17-20关(每日四关)持续更新!!!
  • YOLOv5、YOLOv6、YOLOv7、YOLOv8、YOLOv9、YOLOv10、YOLOv11 推理的 C++ 和 Python 实现
  • HarmonyOS 4.0增强的安全性
  • 自选择问题和处理效应模型
  • 逆元(模板)
  • 【GeekBand】C++设计模式笔记1_介绍
  • Azkaban、oozie、airflow、dolphinschduler 对比分析
  • 工作分享,中芯国际招聘,附送內推码
  • QT之QML学习五:添加自定义Qml组件,以及组件管理
  • ①MongoDB基本知识①
  • Windows与Linux下 SDL2的第一个窗口程序
  • 28BYJ-48步进电机详解(五线四相 STM32)
  • 『功能项目』播放动画时禁止点击移动【40】
  • Leetcode 第 138 场双周赛题解
  • 基于物联网的智能控制系统设计方案——物联网智能化控制箱
  • dp + 计数,CF 1920 E - Counting Binary Strings
  • ‌汽车一键式启动系统‌包含哪些功能
  • ARM32开发——DMA
  • C++ 二叉树进阶
  • STM32L051K8U6-HAL-串口中断控制灯闪烁速度
  • php反序列化基础
  • ultralytics实现DeepSort之级联匹配