设为首页 收藏本站
查看: 566|回复: 0

[经验分享] MySQL查询缓存详解

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-12-20 08:54:18 | 显示全部楼层 |阅读模式
MySQL查询缓存    
     用于保存MySQL查询语句返回的完整结果,被命中时,
     MySQL会立即返回结果,省去解析、优化和执行等阶段

并发查询量非常大、cup核心数非常多时缓存并不一定有效
(多个线程会争用存储缓存的这段内存空间)


如何检查缓存???
    MySQL保存结果与缓存中:
       把select语句本身做hash计算,计算的结果作为key,查询结果作为value

什么样的语句不会被缓存?
    查询语句中有一些不确定数据时,不会缓存;例如now(),current_time();
    一般来说,如果查询中包含用户自定义函数、存储函数、用户变量、临时表、mysql库中系统表、或者任何包含权限的表,一般都不会缓存

缓存会带来额外开销
    1、每个查询都会先检查是否命中
    2、查询结果要先缓存(写缓存)

查看跟缓存相关的变量
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
mysql> show global variables like 'query_cache%';
+------------------------------+----------+
| Variable_name                | Value    |
+------------------------------+----------+
| query_cache_limit            | 1048576  |
| query_cache_min_res_unit     | 4096     |
| query_cache_size             | 16777216 |
| query_cache_type             | ON       |
| query_cache_wlock_invalidate | OFF      |
+------------------------------+----------+


query_cache_type:查询缓存类型:是否开启缓存功能,开启方式有三种{ON|OFF|DEMAND}
   DEMAND:意味着select语句明确使用sql_cache选项才会缓存 (SQL_NO_CACHE则不会缓存)

query_cache_size:总空间;单位为字节,大小必须为1024的整数倍.mysql启动时,会一次分配并立即初始化这里指定大小的内存空间;
   这意味着,如果修改此大小,会清空缓存并重新初始化的.

query_cache_min_res_unit:存储缓存的最小内存块;(query_cache_size - Qcache_free_memory) / Qcache_queries_in_cache 能够获得一个理想的值
   设置过大,容易浪费;设置过小,容易产生大量碎片

query_cache_limit:单个缓存对象的最大值,超出时则不予缓存;手动使用SQL_NO_CACHE可以人为的避免尝试缓存返回超出此参数限定值得语句

query_cache_wlock_invalidate:如果某个表被其他用户连接锁住了,是否仍然从缓存中返回结果,OFF表示返回






如何判断命中率:
    分为次数和字节命中率(命中以后,所省去的数据传输量或解析本身所开销的大小)

1
2
3
4
5
6
7
8
9
10
11
12
13
mysql> show global status like 'Qcache%';
+-------------------------------------------------+----------+
| Variable_name                                   | Value    |
+-------------------------------------------------+----------+
| Qcache_free_blocks(空闲块数)                  | 1        |
| Qcache_free_memory(空闲空间)                  | 16759688 |
| Qcache_hits(命中次数)                         | 0        |
| Qcache_inserts (插入次数)                       | 2        |
| Qcache_lowmem_prunes(内存太小,修剪内存的次数) | 0        |
| Qcache_not_cached(没被缓存的个数)             | 8        |
| Qcache_queries_in_cache(缓存中缓存的查询个数) | 0        |
| Qcache_total_blocks(总块数)                   | 1        |
+-------------------------+----------------------------------+




                       
碎片整理 mysql > flush query_cache
清空缓存 mysql > reset query_cache

计算命中率:
mysql > show global status where Vaiable_name='Qcache_hits' OR Variable_name='Com_Select';
Qcache_hits/(Qcache_hits + Com_Select)

1
2
3
4
5
6
7
8
9
mysql> show global status where Variable_name='Qcache_hits' OR Variable_name='Com_Select';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| Com_select    | 25    | // 总查询此时,命中则不会累计
| Qcache_hits   | 3     |
+---------------+-------+

命中率=3/(3+25)






缓存优化思路
    1.批量写入,而非多次单个写入
    2.缓存空间不宜过大,因为大量缓存同事失效时会导致服务器假死
    3.必要时,使用sql_CACHE和sql_no_cache手动控制缓存。
    4.对写密集型的应用场景来说,禁用缓存反而提高性能。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-316737-1-1.html 上篇帖子: 修改mysql的数据目录 下篇帖子: mysql innodb 死锁分析
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表