本文主要介绍云数据库RDS MySQL版查询缓存(Query Cache)的设置和使用等信息。
阿里云提醒您:
- 如果您对实例或数据有修改、变更等风险操作,务必注意实例的容灾、容错能力,确保数据安全。
- 如果您对实例(包括但不限于ECS、RDS)等进行配置与数据修改,建议提前创建快照或开启RDS日志备份等功能。
- 如果您在阿里云平台授权或者提交过登录账号、密码等安全信息,建议您及时修改。
在MySQL 5.7(内核小版本20200331或以上)版本中,推出了Fast Query Cache功能。若您需要使用该功能,请参见Fast Query Cache。
查询缓存并不一定会带来性能上的提升,在某些情况下(例如查询数量大,但重复的查询很少)开启查询缓存会带来性能的下降。
RDS MySQL对来自客户端的查询(select)进行Hash计算得到该查询的Hash值,然后通过该Hash值到查询缓存中匹配该查询的结果。
查询涉及的任何一个表中数据发生变化,RDS MySQL将查询缓存中所有与该表相关的查询结果集全部释放。
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的整数倍,否则会提示指定参数无效。
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关闭查询缓存。
show global status like 'Qca%';系统显示类似如下。
说明:
Qcache_hits:查询缓存命中次数。
Qcache_inserts:将查询和结果集写入到查询缓存中的次数。
Qcache_not_cached:不可以缓存的查询次数。
Qcache_queries_in_cache:查询缓存中缓存的查询量。