《MySQL面试小抄》查询缓存机制终面

我是肥哥,一名不专业的面试官!

我是囧囧,一名积极找工作的小菜鸟!

囧囧表示:小白面试最怕的就是面试官问的知识点太笼统,自己无法快速定位到关键问题点!!!


本期主要面试考点

面试官考点之简述一下什么是查询缓存机制?
面试官考点之查询如何命中缓存?
面试官考点之什么场景下SQL和结果集不会被缓存?
面试官考点之什么场景下会导致MySQL缓存失效?
面试官考点之查询缓存是如何进行内存管理的?
面试官考点之MySQL是一次性分配所有的内存空间吗?
面试官考点之缓存中的内存碎片无法避免,那么有什么办法优化吗?
面试官考点之MySQL4.0提出了查询缓存,它设计出来是为了加速哪些查询场景?
面试官考点之MySQL5.6中默认禁用,8.0以后完全移除,造成这个改变的原因是什么?
面试官考点之生产环境要不要开启MySQL缓存?

面试官考点之简述一下什么是查询缓存机制?

MySQL服务器高负载情况下,我们需要采取一种措施给服务器减轻压力,一个复杂的查询是非常消耗性能的,

其中磁盘IO又占据主要资源,缓存是对系统性能优化的一种重要手段。

查询缓存机制设计是为了从根本上减少磁盘IO次数,MySQL开启缓存后,将SQL和结果集以键值对KV的形式存储在内存中。

当相同的SQL再次进入,MySQL识别是相同查询喉,会直接返回缓存在内存中的结果集。

避免再次进行一系列复杂的解析优化和磁盘IO过程。

面试官考点之查询如何命中缓存?

select id from user;

select id FROM user;

上面语句能命中缓存吗?

MySQL缓存命中机制有严格苛刻的要求,在判断命中前,MySQL不会对SQL做任何的解析处理。

SQL上的任何字符的不同,如大小写、空格、注释等都会导致缓存不命中

所以上面查询时无法命中缓存的。

面试官考点之什么场景下SQL和结果集不会被缓存?

或者说缓存规则是什么?

第一种情况:查询语句中包含不确定数据

例如查询语句中包含不确定函数:NOW()、CURRENT_DATE()等。

因为每次执行这类带了不确定数据的查询所返回结果可能是不同的。

第二种情况:超过了query_cache_limit预设阈值

超出了缓存内存能承受的范围,将放弃缓存!

面试官考点之什么场景下会导致MySQL缓存失效?

任何对于表结构或者表数据的更新操作,一定会造成查询缓存中的数据失效,同时查询缓存值的相关条目也会被清空。

MySQL判定有更新操作,就会设置所有的查询缓存失效。

面试官考点之查询缓存是如何进行内存管理的?

MySQL服务启动,缓存机制会在内存中开辟一块内存,

其中会划分出一块区域专用来管理维护缓存数据的元数据

例如空间内存、数据表和查询结果的映射,SQL和查询结果的映射

MySQL缓存机制将剩余的空闲空间分为一个个小数据块,用来存储缓存结果。

每个小块中存储自身的类型,大小和查询结果数据,还有指向前后内存块的指针

面试官考点之MySQL是一次性分配所有的内存空间吗?

MySQL因为无法预知查询结果大小,所以无法为每个查询结果精确分配大小恰好匹配的缓存空间。

MySQL缓存机制采用的是边查边存,动态的去申请缓存内存。

一条SQL查询缓存分配内存过程是怎么样的?

当有查询结果需要缓存的时候,MySQL缓存机制会在SQL查询开始(还未得到结果)时就去申请一块内存空间(小数据块),在不断查询中,如果发现不够则继续申请如果存储完时有空余则释放多余的内存空间

如果余下的需要回收的空间很小,小于query_cache_min_res_unit,不能再次被使用,可能会造成内存碎片,影响查询性能。

面试官考点之缓存中的内存碎片无法避免,那么有什么办法优化吗?

没有什么办法能够完全避免内存碎片,但是选择合适的

query_cache_min_res_unit

可以减少由碎片导致的内存空间浪费。

值太小,则浪费的空间更少,但是会导致频繁的内存块申请操作
如果设置得太大,那么碎片会很多

调整合适的值其实是在平衡内存浪费和CPU消耗

那么我如何确定这个平衡值?

可以通过内存实际消耗,计算单个查询的平均缓存大小

(query_cache_size - Qcache_free_memory)/ Qcache_queries_in_cahce

通过查看闲置内存块数量(Qcahce_free_blocks)来观察碎片。

如果产生的碎片过多,通过什么方法可以整理碎片?

通过FLUSH_QUERY_CAHCE清理碎片

这个命令将所有的查询缓存重新排序,

并将所有的空闲空间都聚焦到查询缓存的一块区域上。

面试官考点之MySQL4.0提出了查询缓存,它设计出来是为了加速哪些查询场景?

1、并发性和查询QPS不高 2、被访问的底层数据本质上是静态或半静态的 3、查询密集型应用,更新频率非常低而只读查询频率非常高的场景

面试官考点之MySQL5.6中默认禁用,8.0以后完全移除,造成这个改变的原因是什么?

理想情况下,上述查询场景非常适合使用查询缓存,但是实际的业务系统都是有CRUD操作的。

在MySQL里QC是由一个全局锁在控制,每次更新QC的内存块都需要进行锁定,数据更新频繁,就会不断的失效缓存操作,同时缓存失效会造成大量的查询缓存碎片化,还会导致服务器的负载升高,影响数据库的稳定性。

所以MySQL官方经过抉择,果断移除了查询缓存模块。

面试官考点之生产环境要不要开启MySQL缓存?

建议不开启

根据MySQL官方的测试,如果对一个表执行简单的查询,

设置每次查询都不一样,

打开QC后,性能反而下降了13%左右

当然实际业务中,不会都是这种不同的请求,因此实际影响应该比这个小一些。

MySQL查询缓存的目的是为了提升查询性能,但它本身也是有性能开销的。

需要在合适的业务场景下(读写压力模型)使用

不合适的业务场景不但不能提升查询性能,查询缓存反而会变成MySQL的瓶颈。

对写密集型的应用场景来说,禁用缓存反而提高性能。

随缘更新,整理不易,欢迎联系小白讨论,大神巴巴请绕路!

更多精彩内容,欢迎关注微信公众号:囧么肥事 (或搜索:jiongmefeishi)

《MySQL面试小抄》查询缓存机制终面的更多相关文章

  1. 《MySQL面试小抄》索引考点二面总结

    <MySQL面试小抄>索引考点二面总结 我是肥哥,一名不专业的面试官! 我是囧囧,一名积极找工作的小菜鸟! 囧囧表示:小白面试最怕的就是面试官问的知识点太笼统,自己无法快速定位到关键问题点 ...

  2. 《MySQL面试小抄》索引考点一面总结

    <MySQL面试小抄>索引考点一面总结 我是肥哥,一名不专业的面试官! 我是囧囧,一名积极找工作的小菜鸟 囧囧表示:面试最怕的就是面试官问的知识点太笼统,自己无法快速定位到关键问题点!!! ...

  3. 《MySQL面试小抄》索引失效场景验证

    我是肥哥,一名不专业的面试官! 我是囧囧,一名积极找工作的小菜鸟! 囧囧表示:小白面试最怕的就是面试官问的知识点太笼统,自己无法快速定位到关键问题点!!! 本期主要面试考点 面试官考点之什么情况下会索 ...

  4. MySQL 查询缓存机制(MySQL数据库调优)

    查询缓存机制:缓存的是查询语句的整个查询结果,是一个完整的select语句的缓存结果 哪些查询可能不会被缓存 :查询中包含UDF.存储函数.用户自定义变量.临时表.mysql库中系统表.或者包含列级别 ...

  5. MySQL/MariaDB数据库的查询缓存优化

    MySQL/MariaDB数据库的查询缓存优化 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL架构 Connectors(MySQL对外提供的交互接口,API): ...

  6. day06 内存地址 小数据池缓存机制

    1. 内存相关 示例一 v1=[11,22,33] v2=[11,22,33] #值相等 内存地址不等 v1=11 v2=11 #按理说内存地址应该不等,但是python为了优化使其内存地址相等 v1 ...

  7. mysql(五)查询缓存

    mysql的逻辑架构图如下: 当开启查询缓存时,mysql会将查询结果缓存到查询缓存区域,结果对应的key是使用查询语句,数据库名称,客户端协议的版本等因素算出的一个hash值. 在下次查询时,根据一 ...

  8. Mysql优化之——启用查询缓存

    启用MySQL查询缓存可以极大地减低数据库服务器的CPU使用率,实际使用情况是:开启前CPU使用率120%左右,开启后降到了10%. 查看查询缓存情况: mysql> show variable ...

  9. 解决小程序webview缓存机制

    在打开webview的时候在地址后面加上随机数或者字符串 并且H5页面使用文件hash

随机推荐

  1. 0704-使用GPU加速_cuda

    0704-使用GPU加速_cuda 目录 一.CPU 和 GPU 数据相互转换 二.使用 GPU 的注意事项 三.设置默认 GPU 四.GPU 之间的切换 pytorch完整教程目录:https:// ...

  2. 已知a=a

    高中时酷爱经济学. 薄薄的纸片竟然决定着整个社会的运转趋势,整个人生的起伏也是靠着纸片来衡量的. 可笑的是你怎么闹腾也逃不过康波周期等一系列命中注定的路线,即,已知a=a,那么a等于且仅等于a. 所有 ...

  3. php异常及错误信息捕获并记录日志实现方法全解析

    php异常处理 什么是异常? PHP 5 提供了一种新的面向对象的错误处理方法.异常处理用于在指定的错误(异常)情况发生时改变脚本的正常流程.这种情况称为异常. 当异常被触发时,通常会发生: 当前代码 ...

  4. Vue学习(二)-Vue中组件间传值常用的几种方式

    版本说明:vue-cli:3.0 主要分为两类: 1.父子组件间的传值 2.非父子组件间的传值 1.父子组件间传值 父组件向子组件传值 第一种方式: props 父组件嵌套的子组件中,使用v-bind ...

  5. 【工具库】Java实体映射工具MapStruct

    一.什么是MapStruct? MapStruct是用于代码中JavaBean对象之间的转换,例如DO转换为DTO,DTO转换为VO,或Entity转换为VO等场景,虽然Spring库和 Apache ...

  6. hdu1358 最小循环节,最大循环次数 KMP

    题意:       给你一个字符串,让你找到一些字符串,这个字符串是从第一个字母开始的,并且他可以分成1个一上循环子结构够成的,比如 abcabcabc  那么当前的这个串就是三个abc构成的,他的A ...

  7. 阿里早期Android加固代码的实现分析

    本文博客地址:http://blog.csdn.net/qq1084283172/article/details/78320445 看雪上有作者(寒号鸟二代)将阿里移动早期的Android加固进行了逆 ...

  8. CVE-2014-7911学习笔记

    工作日分析的差不多了,写个标题周末搞

  9. adbi学习:so hook实现机制

    本篇我们来看看adbi的实现原理,其实里面的知识点前面差不多都有涉及了,没多少新知识.adbi利用hijack程序将libexample.so注入到指定的进程中,并且在进程中加载libexample. ...

  10. Python中Numpy模块的使用

    目录 NumPy ndarray对象 Numpy数据类型 Numpy数组属性 NumPy NumPy(Numerical Python) 是 Python 的一个扩展程序库,支持大量的维度数组与矩阵运 ...