MySQL设置查询缓存的用意:

  把查询到的结果缓存起来,下次再执行相同查询时就可以直接从结果集中取;这样就比重新查一遍要快的多。

查询缓存的最终结果是事与愿违:

  之所以查询缓存并没有能起到提升性能的做用,客观上有如下两点原因

  1、把SQL语句的hash值作为键,SQL语句的结果集作为值;这样就引起了一个问题如 select user from mysql.user 和 SELECT user FROM mysql.user

  这两个将会被当成不同的SQL语句,这个时候就算结果集已经有了,但是一然用不到。

  2、当查询所基于的低层表有改动时与这个表有关的查询缓存都会作废、如果对于并发度比较大的系统这个开销是可观的;对于作废结果集这个操作也是要用并发

  访问控制的,就是说也会有锁。并发大的时候就会有Waiting for query cache lock 产生。

  3、至于用不用还是要看业务模型的。

如果何配置查询缓存:

  query_cache_type 这个系统变量控制着查询缓存工能的开启的关闭。

  query_cache_type=0时表示关闭,1时表示打开,2表示只要select 中明确指定SQL_CACHE才缓存。

  这个参数的设置有点奇怪,1、如果事先查询缓存是关闭的然而用 set @@global.query_cache_type=1; 会报错

  ERROR 1651 (HY000): Query cache is disabled; restart the server with query_cache_type=1 to enable it

  2、如果事先是打开着的尝试去闭关它,那么这个关闭也是不完全的,这种情况下查询还是会去尝试查找缓存。

  最好的关闭查询缓存的办法就是把my.cnf 中的query_cache_type=0然后再重启mysql。

查询缓存相关的系统变量:

  have_query_cache  表示这个mysql版本是否支持查询缓存。

  query_cache_limit   表示单个结果集所被允许缓存的最大值。

  query_cache_min_res_unit  每个被缓存的结果集要占用的最小内存。

  query_cache_size  用于查询缓存的内存大小。

如何监控查询缓存的命中率:

  Qcache_free_memory  查询缓存目前剩余空间大小。

  Qcache_hits          查询缓存的命中次数。

  Qcache_inserts      查询缓存插入的次数。

  也就是说缓存的命中率为 Qcache_hits/(Qcache_hits+Qcache_inserts)

最新文章

  1. JavaScript系列文章:自动类型转换-续
  2. Ubuntu/linux 有关权限修改的命令
  3. ROS系统python代码测试之rostest
  4. C#,往线程里传参数的方法总结
  5. vs c++中读取数据流并存储
  6. 关于dom ready事件
  7. 栅栏 CyclicBarrier
  8. 【转】C++中的虚函数的实现
  9. PHP之APC缓存详细介绍
  10. shell全备份脚本(借鉴别人的,在其基础上修复完善了bug)
  11. xmlplus 组件设计系列之零 - xmlplus 简介
  12. lambda+mutable配合move实现单函数多程序域
  13. [Swift]LeetCode1016. 子串能表示从 1 到 N 数字的二进制串 | Binary String With Substrings Representing 1 To N
  14. VNPY加密教程(Python生成pyd文件)
  15. Exp2 后门原理与实践 20165110
  16. php快速无限遍历递归文件夹目录、子文件,支持绝对路径和相对路径,支持返回生成数组
  17. 【GMT43智能液晶模块】例程六:WWDG看门狗实验——复位ARM
  18. bzoj3678 简单题
  19. Hive安装 和管理
  20. 【剑指offer】将字符串中的空格替换成"%20"

热门文章

  1. information_schema.columns 学习
  2. select操作
  3. 验证abc三列数字符合我的小弟要求
  4. Keil C51 与 ARM 并存方法
  5. javascript之尺寸,位置,溢出
  6. StreamReader与StreamWriter
  7. 点击Winform右下角图标,在最前端展示窗口
  8. 国际化标签 <fmt:bundle>&<fmt:message>的使用
  9. cf472D Design Tutorial: Inverse the Problem
  10. 使用univocity-parsers创建和读取csv文件