MySQL查询缓存变量的相关解释

数据库 MySQL
MySQL中的查询缓存变量很多,下文就为您分类解释MySQL查询缓存变量,希望对你学习MySQL数据库能够有所帮助。

对于数据库系统来说,查询是最重要的功能,下面就为您解释MySQL查询缓存变量,如果您对MySQL查询缓存变量方面感兴趣的话,不妨一看。

MySQL查询缓存变量解释:

Qcache_free_blocks:缓存中相邻内存块的个数。数目大说明可能有碎片。FLUSH QUERY CACHE会对缓存中的碎片进行整理,从而得到一个空闲块。

Qcache_free_memory:缓存中的空闲内存。

Qcache_hits:每次查询在缓存中命中时就增大

Qcache_inserts:每次插入一个查询时就增大。命中次数除以插入次数就是不中比率。

Qcache_lowmem_prunes:缓存出现内存不足并且必须要进行清理以便为更多查询提供空间的次数。这个数字最好长时间来看;如果这个 数字在不断增长,就表示可能碎片非常严重,或者内存很少。(上面的 free_blocks和free_memory可以告诉您属于哪种情况)

Qcache_not_cached:不适合进行缓存的查询的数量,通常是由于这些查询不是 SELECT 语句或者用了now()之类的函数。

Qcache_queries_in_cache:当前缓存的查询(和响应)的数量。

Qcache_total_blocks:缓存中块的数量。

query_cache_limit:超过此大小的查询将不缓存

query_cache_min_res_unit:缓存块的最小大小

query_cache_size:查询缓存大小

query_cache_type:缓存类型,决定缓存什么样的查询,示例中表示不缓存 select sql_no_cache 查询

query_cache_wlock_invalidate:当有其他客户端正在对MyISAM表进行写操作时,如果查询在query cache中,是否返回cache结果还是等写操作完成再读表获取结果。

query_cache_min_res_unit的配置是一柄”双刃剑”,默认是4KB,设置值大对大数据查询有好处,但如果你的查询都是小数据 查询,就容易造成内存碎片和浪费。

查询缓存碎片率 = Qcache_free_blocks / Qcache_total_blocks * 100%

如果查询缓存碎片率超过20%,可以用FLUSH QUERY CACHE整理缓存碎片,或者试试减小query_cache_min_res_unit,如果你的查询都是小数据量的话。

查询缓存利用率 = (query_cache_size - Qcache_free_memory) / query_cache_size * 100%

查询缓存利用率在25%以下的话说明query_cache_size设置的过大,可适当减小;查询缓存利用率在80%以上而且 Qcache_lowmem_prunes > 50的话说明query_cache_size可能有点小,要不就是碎片太多。

查询缓存命中率 = (Qcache_hits - Qcache_inserts) / Qcache_hits * 100%

示例服务器 查询缓存碎片率 = 20.46%,查询缓存利用率 = 62.26%,查询缓存命中率 = 1.94%,命中率很差,可能写操作比较频繁吧,而且可能有些碎片。

 

 

【编辑推荐】

MySQL无重复查询的实现

mysql命令行cmd环境下转编码简介

mysql命令行参数简介

MySQL命令行乱码问题的解决

Mysql命令行导入sql数据的实现

责任编辑:段燃 来源: 互联网
相关推荐

2010-10-14 15:59:30

MySQL查询缓存变量

2010-06-02 13:33:19

MySQL 查询缓存

2010-05-19 12:44:58

2010-10-13 16:44:10

MySQL查询缓存机制

2019-11-20 10:50:06

MySQLhandler参数

2010-06-02 17:46:54

MySQL 查询缓存

2010-11-25 09:37:14

MySQL查询缓存机制

2009-08-06 15:12:22

C#异常机制

2017-09-18 15:20:02

MySQL慢查询日志配置

2019-07-11 08:45:00

MySQL数据库缓存

2010-11-25 11:51:53

MySQL查询行号

2020-12-21 09:00:04

MySQL缓存SQL

2022-12-26 08:13:54

子查询MySQL

2018-11-01 08:58:28

物联网术语IOT

2009-04-02 09:36:09

稳定查询MySQL

2020-12-21 09:44:53

MySQL查询缓存数据库

2009-12-24 15:34:44

ADO步骤

2022-11-21 08:21:04

MySQL子查询

2010-04-23 16:35:02

Oracle 查询记录

2011-08-05 15:51:44

MySQL数据库缓存
点赞
收藏

51CTO技术栈公众号