360SDN.COM

首页/MySQL/列表

MySQL开启查询缓存(query_cache_size,query_cache_type)

来源:  2018-07-17 20:35:19    评论:0点击:

启用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';


#show variables like 'have_query_cache';是否开启了缓存
#select @@global.query_cache_size; 缓存空间大小,如是0则缓存不可用
#select @@global.query_cache_type; on是sql语句都缓存;demand是仅仅缓存select sql_cache ...的查询
#set @@global.query_cache_size = 1000000; 设置缓存 1M
#set @@global.query_cache_type=demand; 设置缓存类型demand  sql语句设置sql_cache才缓存
#reset query_cache;整理碎片
#flush tables; 清空缓存
#show status like 'qcache%' 查询缓存情况
#show status like 'qcache_q%'查询缓存结果集
#select sql_cache *from ky_users;
#show status like 'qcache_q%'
#show status like 'qcache_h%'
#select sql_cache *from ky_users;
#show status like 'qcache_h%'

show status like '%Com_select%';

 

可在my.ini中[mysqld]后添加

 query_cache_size=128M
 query_cache_type=1  //1代表on;2代表demand
为您推荐

友情链接 |九搜汽车网 |手机ok生活信息网|ok生活信息网|ok微生活
 Powered by www.360SDN.COM   京ICP备11022651号-4 © 2012-2016 版权