zoukankan      html  css  js  c++  java
  • mysql(五)查询缓存

    mysql的逻辑架构图如下:

    当开启查询缓存时,mysql会将查询结果缓存到查询缓存区域,结果对应的key是使用查询语句,数据库名称,客户端协议的版本等因素算出的一个hash值。

    在下次查询时,根据一些条件计算出hash值,如果能与引用表中的数据相关联,则表示查询命中。

    可以通过如下sql查看查询缓存的状态。

    show variables like '%query_cache%';

    MYSQL提供了一些参数来控制查询缓存的行为,参数如下

    ·              query_cache_limit

    MYSQL能够缓存的最大查询结果,查询结果大于该值时不会被缓存。默认值是1048576(1MB)

    如果某个查询的结果超出了这个值,Qcache_not_cached的值会加1,如果某个操作总是超出可以考虑在SQL中加上SQL_NO_CACHE来避免额外的消耗

    ·              query_cache_min_res_unit

    查询缓存分配的最小块的大小(字节)。 默认值是4096(4KB)。

    ·              query_cache_size

    为缓存查询结果分配的内存的数量,单位是字节,且数值必须是1024的整数倍。默认值是0,即禁用查询缓存。请注意即使query_cache_type设置为0也将分配此数量的内存。

    ·              query_cache_type

    设置查询缓存类型。设置GLOBAL值可以设置后面的所有客户端连接的类型。客户端可以设置SESSION值以影响他们自己对查询缓存的使用。下面的表显示了可能的值:

    选项

    描述

    0或OFF

    不要缓存或查询结果。请注意这样不会取消分配的查询缓存区。要想取消,你应将query_cache_size设置为0。

    1或ON

    缓存除了以SELECT SQL_NO_CACHE开头的所有查询结果。

    2或DEMAND

    只缓存以SELECT SQL_NO_CACHE开头的查询结果。

    该变量默认设为ON。

    ·              query_cache_wlock_invalidate

    一般情况,当客户端对MyISAM表进行WRITE锁定时,如果查询结果位于查询缓存中,则其它客户端未被锁定,可以对该表进行查询。将该变量设置为1,则可以对表进行WRITE锁定,使查询缓存内所有对该表进行的查询变得非法。这样当锁定生效时,可以强制其它试图访问表的客户端来等待。

    查询缓存的优化

    当开启了查询缓存的功能后,可以通过一些参数以及状态值来观察查询缓存的使用情况。

    流程以及涉及到的参数参见下图

    查询缓存的优化

    除了上图提到的一些优化策略外,还可以通过下面的措施来提高查询缓存的效率

    ·              尽量用小表的简单替代大表的复杂查询

    ·              尽量用批量写入取代单条写入

    ·              控制query_cache_size的大小,甚至是禁用查询缓存

    ·              通过DEMAND+SQL_CACHE/SQL_NO_CACHE来灵活控制某个select是否需要进行缓存

    ·              对于写密集型的应用,直接禁用查询缓存

  • 相关阅读:
    2014年工作中遇到的20个问题:120-140
    迷茫与飞跃:9月开始,明确了研究方向,功力提升明显,成绩比较显著
    迷茫与飞跃:9月开始,明确了研究方向,功力提升明显,成绩比较显著
    Freemarker中的日期转换
    Freemarker中的日期转换
    Java实现统计方案
    Java实现统计方案
    Java实现【USACO】1.1.2 贪婪的礼物送礼者 Greedy Gift Givers
    Java实现【USACO】1.1.2 贪婪的礼物送礼者 Greedy Gift Givers
    Java实现【USACO】1.1.2 贪婪的礼物送礼者 Greedy Gift Givers
  • 原文地址:https://www.cnblogs.com/asfeixue/p/9238404.html
Copyright © 2011-2022 走看看