阿里云RDS读写分离数据查询延迟解决方法-阿里云开发者社区

开发者社区> 数据库> 正文
登录阅读全文

阿里云RDS读写分离数据查询延迟解决方法

简介:

mysql使用RDS做数据主从读写分离。在使用的过程中发现部分业务对其他服务以来严重。但是由于系统不是采用微服务的架构,造成部分数据插入数据库后,后续操作读取数据库没有查询到前面插入的数据。查看阿里云服务器找到了一个解决方案:即在sql语句前增加/FORCE_MASTER/ 注释。rds就会自动读主库。详细介绍如下:

阿里云内部网络会确保同步日志在主实例和只读实例间的实时传输,正常情况下只读实例不会有延迟产生。但受限于 MySQL 本身的复制机制,若同步日志的应用时间较久,会产生数据同步的延迟,这个是 MySQL 尚无法在技术手段上规避的问题。为减小延迟,建议您选用规格不小于主实例的只读实例,从而确保有足够高的性能来应用同步日志。

RDS 读写分离链路支持用户设置对延迟的接受阈值。在读写分离体系下,当某个只读实例的延迟超过该阈值时,系统会自动确保不再转发任何请求至该实例,而将请求转发至其余延迟阈值范围内的实例。当所有只读实例均超过延迟阈值时,若主实例的读请求处理权重不为 0,则所有 selcet 请求都将发往主实例处理;若主实例设置的读请求处理权重为 0,则会返回读请求处理失败的结果。

在使用读写分离过程中,若您需要某些查询语句获取实时性的数据,可通过 Hint 格式将这些查询语句强制转发至主实例执行。RDS 读写分离支持的 Hint 格式为 /FORCE_MASTER/,指定后续 SQL 到主实例执行。例如,在如下语句前加入 Hint 后,不论权重如何设置,该语句一定会路由到主实例上执行。

/FORCE_MASTER/ SELECT * FROM table_name;

阿里云官方帮助文档地址:

https://help.aliyun.com/knowledge_detail/52221.html?spm=5176.7854500.2.3.NqEOh2

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
数据库
使用钉钉扫一扫加入圈子
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

其他文章