mysql rds数据库_云数据库RDS MySQL版查询缓存(Query Cache)的设置和使用

概述

本文主要介绍云数据库RDS MySQL版查询缓存(Query Cache)的设置和使用等信息。

详细信息

阿里云提醒您:

如果您对实例或数据有修改、变更等风险操作,务必注意实例的容灾、容错能力,确保数据安全。

如果您对实例(包括但不限于ECS、RDS)等进行配置与数据修改,建议提前创建快照或开启RDS日志备份等功能。

如果您在阿里云平台授权或者提交过登录账号、密码等安全信息,建议您及时修改。

在最新版的MySQL 8.0中,取消了Query Cache功能,推出了Fast Query Cache功能。若您需要使用该功能,请提交工单申请开通此功能,详情请参见Fast Query Cache。

功能和适用范围

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

功能:

降低CPU使用率。

降低IOPS使用率。

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

适用范围:

表数据修改不频繁、数据偏向静态数据。

查询(select语句)重复度高。

查询结果集小于1MB。

原理

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

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

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

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

限制

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

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

不缓存存储函数(Stored Function)、存储过程(Stored Procedure)、触发器(Trigger)、事件(Event)中的查询。

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

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

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

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

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

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

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

设置

说明:

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

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

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

参数设置

参见控制台参数设置参数。

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

query_cache_size(单位:Byte):查询缓存的大小,默认为3MB。query_cache_size参数值要求设置为1024的整数倍,否则会提示指定参数无效。

571c929b1cdcceec28e31fe9ded84db1.png

query_cache_type:是否开启查询缓存功能。修改query_cache_type参数后,提交参数时,会重启实例。

取值为0:关闭查询功能。

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

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

开启查询缓存的设置

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

关闭查询缓存的设置

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

设置建议

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

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

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

验证效果

控制台

登录RDS控制台,单击实例列表,选择对应的地域,选择目标实例,单击性能趋势,通过MySQL CPU/内存 利用率区域查看资源使用情况。

359a01401dfb32acda60e2f14275a076.png

SQL命令

您可以连接RDS实例,通过以下SQL语句,获取查询缓存的使用状态。

show global status like 'Qca%';

系统显示类似如下。

6b3e03275fe04034d5f4d07100fe2e24.png

说明:

Qcache_hits:查询缓存命中次数。

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

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

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

适用于

云数据库RDS MySQL版

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值