博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql 查询缓存配置和查看
阅读量:7067 次
发布时间:2019-06-28

本文共 2767 字,大约阅读时间需要 9 分钟。

Mysql 查询缓存 

查询缓存的作用就是当查询接收到一个和之前同样的查询,服务器将会从查询缓存种检索结果,而不是再次分析和执行上次的查询。这样就大大提高了性能,节省时间。 
1.配置查询缓存 
修改配置文件,修改[mysqld]下的query_cache_size和query_cache_type(如果没有则添加)。其中query_cache_size表示缓存的大小,而query_cache_type有3个值,表示缓存那种类  型的select结果集,query_cache_type各个值如下: 
0或off关闭缓存 
1或on开启缓存,但是不保存使用sql_no_cache的select语句,如不缓存select  sql_no_cache name from wei where id=2 
2或demand开启有条件缓存,只缓存带sql_cache的select语句,缓存select  sql_cache name from wei where id=4 
例子的配置为下,配置完成重启Mysql服务器即可。

query_cache_size=10M  query_cache_type=1

可以用如下命令查看是否开启,其中have_query_cache为是否开启,query_cache_limit 指定单个查询能够使用的缓冲区大小,缺省为1M;query_cache_min_res_unit为系统分配的最小缓存块大小,默认是4KB,设置值大对大数据查询有好处,但如果你的查询都是小数据 查询,就容易造成内存碎片和浪费;query_cache_size和query_cache_type就是上面我们的配置;query_cache_wlock_invalidate表示当有其他客户端正在对MyISAM表进行写操作时,如果查询在query cache中,是否返回cache结果还是等写操作完成再读表获取结果。 

mysql> show variables like '%query_cache%';  +------------------------------+----------+  | Variable_name                | Value    |  +------------------------------+----------+  | have_query_cache             | YES      |  | query_cache_limit            | 1048576  |  | query_cache_min_res_unit     | 4096     |  | query_cache_size             | 10485760 |  | query_cache_type             | ON       |  | query_cache_wlock_invalidate | OFF      |  +------------------------------+----------+  6 rows in set (0.00 sec)

2.测试 

我们先执行一次,select  count(*) from wei ;然后再执行一次,可以看出第二次用的时间远远低于第一次的执行,因为第二次从缓存中读取了select结果。

mysql> select  count(*) from wei ;  +----------+  | count(*) |  +----------+  |  4194304 |  +----------+  1 row in set (3.92 sec)    mysql> select  count(*) from wei ;  +----------+  | count(*) |  +----------+  |  4194304 |  +----------+  1 row in set (0.00 sec)

我们可以通过如下命令查看现在缓存的情况 :

mysql> show status like 'qcache%';  +-------------------------+----------+  | Variable_name           | Value    |  +-------------------------+----------+  | Qcache_free_blocks      | 1        |  | Qcache_free_memory      | 10475424 |  | Qcache_hits             | 1        |  | Qcache_inserts          | 1        |  | Qcache_lowmem_prunes    | 0        |  | Qcache_not_cached       | 0        |  | Qcache_queries_in_cache | 1        |  | Qcache_total_blocks     | 4        |  +-------------------------+----------+  8 rows in set (0.00 sec)

其中各个参数的意义如下: 

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:缓存中块的数量。

转载于:https://www.cnblogs.com/ccs-mxs/p/6844921.html

你可能感兴趣的文章
(PHP)设置修改 Apache 文件根目录 (Document Root)(转帖)
查看>>
使用sqlite保存数据返回主键
查看>>
js循环生成多个easyui datagrid数据网格时,初始化表格
查看>>
Python编程笔记(第三篇)【补充】三元运算、文件处理、检测文件编码、递归、斐波那契数列、名称空间、作用域、生成器...
查看>>
获取用户信息
查看>>
洛谷P3952 时间复杂度
查看>>
Leetcode | Parentheses 相关
查看>>
Ajax分页问题
查看>>
如何禁止内部viewPager滑动
查看>>
简单的转义字符
查看>>
RabbitMQ入门-Topic模式
查看>>
poj 2777 Count Color(线段树区间更新)
查看>>
Java数据结构与算法(5) - ch05链表(LinkList)
查看>>
CLR Via CSharp读书笔记(21):自动内存管理(垃圾回收)
查看>>
刚刚接触python的感想
查看>>
modelsim使用常见问题及解决办法集锦 ②
查看>>
常用的第三方库
查看>>
java 操作elasticsearch之搭建测试项目环境
查看>>
iOS-图文表并茂,手把手教你GCD
查看>>
python之logging模块
查看>>