电脑疯子技术论坛|电脑极客社区

微信扫一扫 分享朋友圈

已有 1942 人浏览分享

如何启用MySQL查询缓存?

[复制链接]
1942 0

1、启用MySQL查询缓存好处:

可以极大地减低数据库服务器的CPU使用率,实际使用情况是:
开启前CPU使用率120%左右,开启后降到了10%。

2、查看查询缓存情况:

  1. codemysql> show variables like ‘%query_cache%’;/code
  2. (query_cache_type 为 ON 表示已经开启)
  3. +——————————+———-+
  4. | Variable_name | Value |
  5. +——————————+———-+
  6. | have_query_cache | YES |
  7. | query_cache_limit | 1048576 |
  8. | query_cache_min_res_unit | 4096 |
  9. | query_cache_size | 20971520 |
  10. | query_cache_type | ON |
  11. | query_cache_wlock_invalidate | OFF |
  12. +——————————+———-+
复制代码


3、如果不是ON,修改配置文件以开启查询缓存:

  1. vi /etc/my.cnf
  2. [mysqld]中添加:
  3. query_cache_size = 20M
  4. query_cache_type = ON
复制代码


4、重启mysql服务:

  1. service mysql restart
复制代码


5、查看缓存使用情况:

  1. mysql> show status like ‘qcache%’;
  2. +————————-+———-+
  3. | Variable_name | Value |
  4. +————————-+———-+
  5. | Qcache_free_blocks | 83 |
  6. | Qcache_free_memory | 19811040 |
  7. | Qcache_hits | 3108196 |
  8. | Qcache_inserts | 757254 |
  9. | Qcache_lowmem_prunes | 20720 |
  10. | Qcache_not_cached | 47219 |
  11. | Qcache_queries_in_cache | 47 |
  12. | Qcache_total_blocks | 276 |
  13. +————————-+———-+
复制代码


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

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

7、对于某些不想使用缓存的语句,可以这样使用:

  1. select SQL_NO_CACHE count() from t_user where tell = ‘153*******‘;
复制代码



您需要登录后才可以回帖 登录 | 注册

本版积分规则

1

关注

0

粉丝

9021

主题
精彩推荐
热门资讯
网友晒图
图文推荐

Powered by Pcgho! X3.4

© 2008-2022 Pcgho Inc.