• 1
  • 2
  • 3
  • 4
  • 5
mysql数据库问题 首 页  »  帮助中心  »  数据库  »  mysql数据库问题
关于RDS MySQL查询缓存(Query Cache)的设置和使用方法
发布日期:2015-11-7 13:11:43

  关于RDS MySQL查询缓存(Query Cache)的设置和使用方法

   1.查询缓存原理

  一般来说,RDS MySQL 对来自客户端的查询(Select)进行 Hash 计算得到该查询的Hash值,然后再通过该Hash 值到查询缓存中匹配该查询的结果。

  如果没有匹配(命中),就将 Hash 值和结果集保存在查询缓存中,以便以后使用。

        如果匹配(命中),就将查询的结果集直接返回给客户端,不必再解析、执行查询。

     查询涉及的任何一个表中数据发生变化,RDS MySQL 将查询缓存中所有与该表相关的查询结果集全部释放(删除)。

            2. 查询缓存的功能和适用范围

  查询缓存功能:

  降低 IOPS 使用率(某些情况下)

        降低 CPU 使用率

  减少查询响应时间,提高系统的吞吐量

    表数据修改不频繁、数据较静态

    查询(Select)重复度高

       查询缓存适用范围

   查询结果集小于 1MB

  注:查询缓存并不是一定可以带来性能上的提升,在某些情况下(比如查询数量大,但重复的查询很少)开启查询缓存反而会带来性能的下降。

   3.查询缓存的限制

  查询必须要求严格一致(大小写、空格、使用的数据库、协议版本、字符集等必须一致)才可以命中,要不然视为不同查询。

  不缓存存储函数(stored function)、存储过程(stored procedure)、触发器(trigger)、事件(event)中的查询。

  不缓存含有每次执行结果变化的函数的查询,比如now()、curdate()、last_insert_id()、rand()等。

        不缓存查询中的子查询结果集,仅缓存查询最终结果集。

  不缓存使用临时表的查询。

  不缓存产生告警(warnings)的查询。

        不缓存对 mysql、information_schema、performance_schema 系统数据库表的查询。

  不缓存 select ... lock in share mode、select ... for update、 select * from ... where autoincrement_col is null 类型的查询。

  不缓存使用 hint - SQL_NO_CACHE 的查询。

        不缓存使用用户定义变量的查询。

    4.查询缓存设置

  4.1 参数(RDS控制台可以设置)

  参数设置路径:RDS 控制台 =》参数设置

  query_cache_limit: 查询缓存中可存放的单条查询最大结果集、默认为 1 MB;超过该大小的结果集不被缓存。

  query_cache_size: 查询缓存的大小。

  query_cache_type: 是否开启查询缓存功能。

  取值为 2 :开启查询缓存功能,但仅缓存 Select SQL_CACHE 开头的查询。

        取值为 1 :开启查询缓存功能,但不缓存 Select SQL_NO_CACHE 开头的查询。

       取值为 0 :关闭查询功能


      注:修改 query_cache_type 需要重启实例(修改后实例会自动重启)。

  4.2关闭

  设置参数query_cache_size 为 0 或者设置 query_cache_type 为 0 关闭查询缓存。

       4.3开启

  参数query_cache_size 大于 0 并且 query_cache_type 设置为 1 或者 2 的情况下,查询缓存开启。

  4.4 建议

  建议query_cache_size 不设置的过大,过大的的空间会挤占实例其他内存结构的空间,而且还会增加在缓存中搜索的开销。建议最好根据实例规格,初始值设置为 10MB 到 100 MB 之间的值,而后根据运行使用情况调整。

  建议通过调整query_cache_size的值来开启、关闭查询缓存,因此修改query_cache_type 参数需要重启实例生效。

  查询缓存适用于特定的场景,建议充分测试后,再考虑开启,避免引起性能下降或引入其他问题。

  5.验证效果

  5.1 控制台


  5.2 SQL 命令


  可以通过 show global status like 'Qca%' 来获取查询缓存的使用状态。

  Qcache_inserts:将查询和结果集写入到查询缓存中的次数。

  Qcache_not_cached:不可以缓存的查询次数。

        Qcache_hits :查询缓存命中次数。

  Qcache_queries_in_cache:查询缓存中缓存的查询量。