小编给大家分享一下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查询缓存未命中也是这个道理,具体未命中的原因比较复杂,对应了各自未命中情况的解决原因分析,分别有分点需要我们去理解。
看完了这篇文章,相信你对“mysql如何查询缓存未命中”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
亿速云「云数据库 MySQL」免部署即开即用,比自行安装部署数据库高出1倍以上的性能,双节点冗余防止单节点故障,数据自动定期备份随时恢复。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://www.py.cn/db/mysql/22056.html