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

  • 时间:
  • 浏览:0

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

/FORCE_MASTER/ SELECT * FROM table_name;

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

mysql使用RDS做数据主从读写分离。在使用的过程中发现主次业务对或多或少服务以来严重。本来 将会系统删改还要采用微服务的架构,造成主次数据插入数据库后,后续操作读取数据库这样 查询到前面插入的数据。查看阿里云服务器找到了一个多 多补救方案:即在sql一段话前增加/FORCE_MASTER/ 注释。rds就会自动读主库。删改介绍如下:

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

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

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