几个参数

  query_cache_type:为ON时开启,为OFF关闭,为DEMAND时则只有查询语句中有sql cache时才使用缓存

  query_cache_size: 缓存的内存空间

  query_cache_min_res_unit: 分配内存块的最小单位

  query_cache_limit:缓存可使用的内存最大值

缓存使用及注意

  在使用上缓存后,对于select语句:首先去缓存里查询是否有对应的缓存,具体是根据sql语句和作用的表生成一个key,去内存取值;如果这个key没有缓存,则执行sql语句,再把结果存到缓存中。

  对于增删改语句:执行完增删改语句后,要记录好这些语句影响的表,再去缓存空间中找到从这些表拿到的缓存结果,将这些缓存结果置为失效。

  注意:

    1.  若select中有不确定函数,则用不上缓存。如current_data,因为这个函数的值时刻变化,缓存没有意义

    2. 内存分配要合理,太小影响缓存结果,太大会导致 os 僵死

    3. 内存分配最小单位要设置合理,调小点有利于减少内存碎片,但太小影响分配效率

    4. 缓存也是有很多开销的,如查找,更新,置为失效缓存,以及使用内存时的互斥信号量。要衡量开销与收益

    5. 缓存绝对不适合写多读少的场景,这会频频把缓存置为失效

InnoDB的缓存实现特点

  前面的总结中也提到了InnoDB的MVCC机制,是一种变种的行级锁,这里就不详细介绍了。由于MVCC机制,事务不能使用创建事务ID在自己后面的行的缓存。举个例子:首先是有事务1、2、3、4对某个行进行查询,但由于某些原因他们执行被阻塞,这时事务5也来查询这个行并且成功了,然后把结果缓存起来。但是事务1,2,3,4再继续执行时是不能直接从缓存中拿这个行的,因为这个行的事务标记是晚于他们的事务5,事务1,2,3,4必须老实去执行 sql 语句。

  实际上和MVCC机制下的数据读取类似:为了防止不可重复读,只读创建事务ID晚于自己的行。

建议

  1.  缓存也是有开销的,如果是写多读少的场景,不要用缓存。只有读多,且读操作比较耗时才考虑缓存。

  2. 可以考虑使用专门的表存储某些结果,例如某些统计数字。

  3. 尽量用客户端缓存,这样缓存就与关系数据库无关;缓存数据库和关系数据库分离,不用读写行时维护缓存,操作起来更快。

MySQL--缓存的使用注意的更多相关文章

  1. MYSQL内存--------启动mysql缓存机制,实现命中率100% 转

    虽然这个标题夸张得过了头,但此文很完整,值得学习.转自 http://www.yy520.net/read.php?278 myql优化,启动MySQL缓存机制,实现命中率100% 配置你的mysql ...

  2. MySQL缓存参数优化(转)

    MySQL 数据库性能优化之缓存参数优化 数据库属于 IO 密集型的应用程序,其主要职责就是数据的管理及存储工作.而我们知道,从内存中读取一个数据库的时间是微秒级别,而从一块普通硬盘上读取一个IO是在 ...

  3. mysql 缓存机制

    了解mysql缓存吗(顺丰) mysql缓存机制就是缓存sql 文本及缓存结果,用KV形式保存再服务器内存中,如果运行相同的sql,服务器直接从缓存中去获取结果,不需要在再去解析.优化.执行sql. ...

  4. MySQL缓存分类和配置

    读书笔记,待补充完善 MySQL缓存分类 InnoDB缓冲池 InnoDB日志文件和MyIsAM数据的操作系统缓存 MyIsAM键缓存 查询缓存 无法手工配置的缓存,二进制日志,表定义文件的操作系统缓 ...

  5. MySql 缓存查询原理与缓存监控 和 索引监控

    MySql缓存查询原理与缓存监控 And 索引监控 by:授客 QQ:1033553122 查询缓存 1.查询缓存操作原理 mysql执行查询语句之前,把查询语句同查询缓存中的语句进行比较,且是按字节 ...

  6. MySQL缓存命中率概述及如何提高缓存命中率

    MySQL缓存命中率概述 工作原理: 查询缓存的工作原理,基本上可以概括为: 缓存SELECT操作或预处理查询(注释:5.1.17开始支持)的结果集和SQL语句: 新的SELECT语句或预处理查询语句 ...

  7. Mysql缓存的配置和使用

    在mysql服务器高负载的情况下,必须采取一种措施给服务器减轻压力,减少服务器的I/O操作.一般采用的方法是优化sql操作语句,优化服务器的配置参数,从而提高服务器的性能.Mysql使用了几种内存缓存 ...

  8. mysql缓存、存储引擎

    一.         mysql查询缓存 查询缓存不是mysql的子系统,却是查询优化和执行子系统不可缺少的组成部分.它不仅可以缓存查询结果,还可以缓存查询结果本身.如果某个查询的结果就在缓存里, 系 ...

  9. LRU在MySQL缓存池的实现

    MySQL的InnoDB引擎设置有索引及数据缓存池,其中用到的LRU算法来维持缓存的命中率 这里用到了顺序表list来作为缓冲池,每个数据节点称为block 该算法采用“中点插入法”:当插入一个新bl ...

  10. 合理配置MySQL缓存 提高缓存命中率

    众所周知,系统读取数据时,从内存中读取要比从硬盘上速度要快好几百倍.故现在绝大部分应用系统,都会最大程度的使用缓存(内存中的一个存储区域),来提高系统的运行效率.MySQL数据库也不例外.在这里,笔者 ...

随机推荐

  1. Windows程序调用dll

    可以写在WndProc的WM_CREATE里面,不能写在WinMain里面

  2. 阶段3 1.Mybatis_12.Mybatis注解开发_7 Mybatis注解开发一对多的查询配置

    一对多的配置,一个用户对应多个账户 需要在Accout里面增加根据用户的uid查询的方法 在user里面指定子一对多的查询配置 换行显示 测试 把这里注销掉.测试延迟加载,代码注释掉后,延迟加载就没有 ...

  3. python调用c/c++时传递结构体参数

    背景:使用python调用linux的动态库SO文件,并调用里边的c函数,向里边传递结构体参数.直接上代码 //test1.c # include <stdio.h> # include ...

  4. 中国MOOC_零基础学Java语言_第7周 函数_2完数

    2 完数(5分) 题目内容: 一个正整数的因子是所有可以整除它的正整数.而一个数如果恰好等于除它本身外的因子之和,这个数就称为完数.例如6=1+2+3(6的因子是1,2,3). 现在,你要写一个程序, ...

  5. Application.CreateForm()和TForm.Create()创建的窗体有什么区别么?二者在使用上各有什么技巧?(50分)

    https://wedelphi.com/t/135849/ 请详细些,并给出例子.谢谢. Application.CreateForm()创建的第一个可显示的窗体是自动成为主窗体,并且自动显示,并且 ...

  6. cocos2dx基础篇(8) 开关按钮CCControlSwitch

    [3.x] (1)去掉 “CC” (2)对象类 CCObject 改为 Ref (3)标签类 LabelTTF 改为 Label (4)CCControlEvent 改为强枚举 Control::Ev ...

  7. ElasticSearch Machine Learning

    https://www.youtube.com/watch?v=DBRISS0UKcA, 2017/04 Single Metric job: 我想按照 一定的time interval 去 aggr ...

  8. .net core 学习小结之 Cookie-based认证

    在startup中添加授权相关的管道 using System; using System.Collections.Generic; using System.Linq; using System.T ...

  9. TestNG+extentReports+log4j2 完善自动化测试框架——美观的报告和保留日志文件

    1:导入Maven依赖<dependency> <groupId>com.aventstack</groupId> <artifactId>extent ...

  10. adb 连接 mumu 模拟器

    [win版]adb connect 127.0.0.1:7555adb shell [mac版] adb kill-server && adb server && ad ...