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

5 篇文章 0 订阅

 

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

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个问题涉及到两个方面的内容,一个是如何读取阿里云物联网平台数据,另一个是如何读写阿里云RDS数据库。下面我分别进行解答: 1. 如何读取阿里云物联网平台数据阿里云物联网平台提供了多种接入方式,包括 MQTT、HTTP、CoAP 等。其中 MQTT 是最常用的一种接入方式,也是阿里云物联网平台官方推荐的接入方式。在 MATLAB 中,可以使用 MATLAB 自带的 mqtt 函数库来实现 MQTT 协议的订阅和发布。 首先需要在阿里云物联网平台上创建一个设备,获取到设备的三元组信息(ProductKey、DeviceName 和 DeviceSecret)。然后使用 mqtt 函数库连接到阿里云物联网平台的 MQTT 服务器,并订阅设备的 Topic,就可以收到设备上报的数据了。具体的代码如下: ```matlab % 阿里云物联网平台 MQTT 服务器地址 broker = 'tcp://xxxxx.iot-as-mqtt.cn-shanghai.aliyuncs.com'; % 设备三元组信息 productKey = 'xxxxxxxxxxxxx'; deviceName = 'xxxxxxxxxxxxx'; deviceSecret = 'xxxxxxxxxxxxx'; % MQTT 连接选项 options = mqttv5_options('UserName', productKey + '/' + deviceName, ... 'Password', mqtt_password(productKey, deviceName, deviceSecret), ... 'CleanSession', true, ... 'ConnectTimeout', 30); % MQTT 订阅选项 subscription = mqttv5_subscription(topic, 1); % 连接 MQTT 服务器并订阅 Topic client = mqttv5(broker, options); subscribe(client, subscription); % 循环获取设备上报的数据 while true message = receive(client); data = message.Payload; % 处理数据 ... end % 断开 MQTT 连接 unsubscribe(client, subscription); disconnect(client); ``` 2. 如何读写阿里云RDS数据库阿里云RDS是一种云数据库服务,支持多种数据库类型,包括 MySQL、SQL Server、PostgreSQL、PPAS 等。在 MATLAB 中,可以使用 MATLAB 自带的 Database Toolbox 函数库来连接阿里云RDS数据库,并进行数据读写操作。 首先需要在阿里云RDS上创建一个数据库实例,并开通相应的数据库服务。然后使用 Database Toolbox 函数库连接到阿里云RDS数据库,并执行 SQL 查询语句或更新操作即可。具体的代码如下: ```matlab % 阿里云RDS数据库连接选项 driver = 'com.mysql.jdbc.Driver'; url = 'jdbc:mysql://xxxxxxxxxxxx.rds.aliyuncs.com:3306/xxxxxxxxxxxx'; username = 'xxxxxxxxxxxx'; password = 'xxxxxxxxxxxx'; % 连接阿里云RDS数据库 conn = database('xxxxxxxxxxxx', username, password, driver, url); % 执行 SQL 查询语句 query = 'SELECT * FROM xxxxxxxxxxxx'; curs = exec(conn, query); data = fetch(curs); % 执行 SQL 更新操作 query = 'UPDATE xxxxxxxxxxxx SET xxxxxxxxxxxx = xxxxxxxxxxxx WHERE xxxxxxxxxxxx = xxxxxxxxxxxx'; curs = exec(conn, query); % 关闭数据库连接 close(curs); close(conn); ``` 以上是在MATLAB中读取阿里云物联网平台数据读写阿里云RDS数据库的基本操作,具体实现还需要根据具体情况进行调整和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值