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


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

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

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

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

    1. /*FORCE_MASTER*/ SELECT * FROM table_name;

    阿里云官方文档地址:

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

  • 相关阅读:
    Hook钩子程序
    KMeans笔记 K值以及初始类簇中心点的选取
    自己用C#写的一个俄罗斯方块的小程序(附源代码)。
    那些帮助你成为优秀前端工程师的讲座——《JavaScript篇》
    Mac技巧合集第二期
    WCF增加UDP绑定(应用篇)
    第一个MVC4 Web应用程序
    jQuery的页面加载事件
    通过网页进行 iOS 应用内部分发
    sql count效率
  • 原文地址:https://www.cnblogs.com/zhangshiwen/p/7765522.html
Copyright © 2020-2023  润新知