在MySQL数据库中,查询缓存(Query Cache)是一种用于提升查询性能的机制,它通过缓存SELECT查询的结果集,使得相同的查询在后续请求时可以直接从缓存中获取结果,而不需要再次执行查询操作,查询缓存并不适用于所有场景,特别是在使用RDS for MySQL时,其支持和配置方式也有一定的限制。
一、功能和适用范围
1、降低CPU使用率:通过缓存查询结果,减少重复查询对CPU资源的消耗。
2、降低IOPS使用率:在某些情况下,缓存可以减少对磁盘I/O操作的需求。
3、减少查询响应时间:提高系统的吞吐量,使系统能够更快地响应查询请求。
4、适用场景:表数据修改不频繁、数据较静态;查询(Select)重复度高;查询结果集小于1MB,需要注意的是,查询缓存并不一定在所有情况下都能带来性能上的提升,例如当查询数量大但重复查询很少时,开启查询缓存可能会导致性能下降。
二、原理
RDS for MySQL对来自客户端的查询(Select)进行Hash计算得到该查询的Hash值,通过该Hash值到查询缓存中匹配该查询的结果,如果匹配(命中),则将查询的结果集直接返回给客户端,不必再解析、执行查询,如果没有匹配(命中),则将Hash值和结果集保存在查询缓存中,以便以后使用,查询涉及的任何一个表中数据发生变化,RDS for MySQL将查询缓存中所有与该表相关的查询结果集全部释放(删除)。
三、限制
1、严格一致性要求:查询必须严格一致(大小写、空格、使用的数据库、协议版本、字符集等必须一致)才可以命中,否则视为不同查询。
2、不缓存子查询结果集:仅缓存查询最终结果集。
3、不缓存特定类型的查询:如存储函数(Stored Function)、存储过程(Stored Procedure)、触发器(Trigger)、事件(Event)中的查询;含有每次执行结果变化的函数的查询,比如now()、curdate()、last_insert_id()、rand()等;对mysql、information_schema、performance_schema系统数据库表的查询;使用临时表的查询;产生告警(Warnings)的查询;Select … lock in share mode、Select … for update、 Select * from … where autoincrement_col is NULL类型的查询;使用用户定义变量的查询;使用Hint SQL_NO_CACHE的查询。
四、设置
1、参数说明
query_cache_limit:查询缓存中可存放的单条查询最大结果集,默认为1MB;超过该大小的结果集不被缓存。
query_cache_size:查询缓存的大小。
query_cache_type:是否开启查询缓存功能,取值为0表示关闭查询功能;取值为1表示开启查询缓存功能,但不缓存Select SQL_NO_CACHE开头的查询;取值为2表示开启查询缓存功能,但仅缓存Select SQL_CACHE开头的查询。
2、开启方法:参数query_cache_size大于0并且query_cache_type设置为1或者2的情况下,查询缓存开启。
3、关闭方法:设置参数query_cache_size为0或者设置query_cache_type为0关闭查询缓存。
4、建议:query_cache_size不建议设置的过大,过大的空间不但挤占实例其他内存结构的空间,而且会增加在缓存中搜索的开销,建议根据实例规格,初始值设置为10MB到100MB之间的值,而后根据运行使用情况调整,建议通过调整query_cache_size的值来开启、关闭查询缓存,因为修改query_cache_type参数需要重启实例生效,查询缓存适用于特定的场景,建议充分测试后,再考虑开启,避免引起性能下降或引入其他问题。
五、验证效果
可以通过以下SQL命令来获取查询缓存的使用状态:show global status like 'Qca%';Qcache_hits表示查询缓存命中次数;Qcache_inserts表示将查询和结果集写入到查询缓存中的次数;Qcache_not_cached表示不可以缓存的查询次数;Qcache_queries_in_cache表示查询缓存中缓存的查询量。
六、FAQs
1、Q: RDS for MySQL是否支持开启查询缓存?
A: 是的,RDS for MySQL支持开启查询缓存,可以通过设置query_cache_size和query_cache_type参数来控制查询缓存的开启和关闭,需要注意的是,查询缓存并不适用于所有场景,且在某些情况下可能会带来性能下降。
2、Q: 如何更改RDS for MySQL的查询缓存大小?
A: 要更改RDS for MySQL的查询缓存大小,可以通过设置query_cache_size参数来实现,这个参数可以在RDS控制台中进行设置,也可以通过修改MySQL配置文件(如my.cnf或my.ini)来实现,需要注意的是,修改query_cache_size参数可能需要重启MySQL服务才能生效。
RDS for MySQL确实支持开启查询缓存,但其使用需要根据具体的业务场景和需求来决定,在使用查询缓存时,需要注意其限制条件,并合理配置相关参数以优化性能,也要意识到查询缓存并非万能解决方案,在某些情况下可能会带来性能问题,建议在充分测试和评估后再决定是否启用查询缓存。