启用MySQL查询缓存

Posted Brenda

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了启用MySQL查询缓存相关的知识,希望对你有一定的参考价值。

启用mysql查询缓存能够极大地减低数据库server的CPU使用率,实际使用情况是:开启前CPU使用率120%左右,开启后降到了10%。


查看查询缓存情况:
mysql> show variables like ‘%query_cache%‘; 
(query_cache_type 为 ON 表示已经开启)
+------------------------------+----------+
| Variable_name                | Value    |
+------------------------------+----------+
| have_query_cache             | YES      |
| query_cache_limit            | 1048576  |
| query_cache_min_res_unit     | 4096     |
| query_cache_size             | 20971520 |
| query_cache_type             | ON       |
| query_cache_wlock_invalidate | OFF      |
+------------------------------+----------+

假设不是ON,改动配置文件以开启查询缓存:
> vi /etc/my.cnf
[mysqld]中加入:
query_cache_size = 20M
query_cache_type = ON

重新启动mysql服务:
> service mysql restart

查看缓存使用情况:
mysql> show status like ‘qcache%‘;  
+-------------------------+----------+
| Variable_name           | Value    |
+-------------------------+----------+
| Qcache_free_blocks      | 83       |
| Qcache_free_memory      | 19811040 |
| Qcache_hits             | 3108196  |
| Qcache_inserts          | 757254   |
| Qcache_lowmem_prunes    | 20720    |
| Qcache_not_cached       | 47219    |
| Qcache_queries_in_cache | 47       |
| Qcache_total_blocks     | 276      |
+-------------------------+----------+

    当中各个參数的意义例如以下:  
  • 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:缓存中块的数量。

     


对于某些不想使用缓存的语句。能够这样使用:
select SQL_NO_CACHE count(*) from users where email = ‘hello‘;

原创文章。转载请注明转自Clement-Xu的csdn博客。

以上是关于启用MySQL查询缓存的主要内容,如果未能解决你的问题,请参考以下文章

启用MySQL查询缓存

启用MySQL查询缓存

启用 MySQL 和 MariaDB 查询缓存

mysql查看查询缓存是否启用

使用 MySQL 和 JDBC 准备语句缓存

MySQL十大优化技巧详解