栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 数据库 > MySQL

mysql查询缓存未命中

MySQL 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

mysql查询缓存未命中

我们把一个文件进行传输发现对方并没有收到,这就是传送未成功。我们在mysql查询缓存未命中也是这个道理,具体未命中的原因比较复杂,对应了各自未命中情况的解决原因分析,分别有分点需要我们去理解。接下来小编就来带大家看看mysql查询缓存未命中的原因及解决分析。

1.缓存未命中概念:

任何SELECT语句没有从查询缓存中返回都称为“缓存未命中”,以如下列情况:

  • 查询语句无法被缓存,可能因为查询中包含一个不确定的函数,或者查询结果太大而无法缓存。

  • MySQL从未处理这个查询,所以结果也从不曾被缓存过。

  • 虽然之前缓存了查询结果,但由于查询缓存的内存用完了,MYSQL需要删除某些缓存,或者由于数据表被修改导致缓存失效。

2.缓存未命中解决:

如果服务器上有大量缓存缓存未命中,但是实际上绝大查询都被缓存了,那么一定是有如下情况发生:

  • 查询缓存还没有完成预热,即MySQL还没有机会将查询结果都缓存起来。

  • 查询语句之前从未执行过。如果应用程序不会重复执行一条查询语句,那么即使完成预热仍然会有很多缓存未命中。

  • 缓存失效操作太多,缓存碎片、内存不足、数据修改都会造成缓存失效。可以通过参数Com_*来查看数据修改的情况(包括Com_update,Com_delete等),还可以通过Qcache_lowmem_prunes来查看有多少次失效是由于内存不足导致的。

拓展mysql命令:

查看表结构

desc users;

查询配置变量

show variables like '%max_connections%';

%% 之间输入要查询的变量名

比较常用的有:

// 查询线程 
show variables like 'thread%'; 
 
//查询连接 
show variables like '%connect%'; 
 
//查询慢查询日志设置时间  即多慢被认为是慢查询  
show variables like 'long_query_time'; 
 
//查询缓存设置时间  
show status like '%Qcache%'; 
 
//查询mysql redo log 相关信息 
show global variables like '%innodb_log%'; 
 
//查询数据库目录存放位置 
show variables like '%dir%'; 
 
//查询数据库的字符集 
SHOW VARIABLES WHERe Variable_name LIKE 'character_set_%' OR Variable_name LIKE 'collation%';

以上就是我们在mysql查询缓存未命中的情况分析,小伙伴们看懂后就可以对着解决分析去进行调试了,没有遇到这种情况的也可以尝试着去解决以免下次遇到。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/13162.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号