RDS 循序渐进 – 闪断篇

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

阿里云关系型数据库服务(后简称RDS) 为用户提供的诸多功能中,其中有一个最基本也最为重要的特性:快速为用户部署一个“高可用”的数据库环境。本篇我们主要一起来探讨RDS“高可用”的实现方案以及在此方案中出现的“闪断”情况。

 

RDS高可用实现方案

RDS 为保证高可用服务,为每个用户购买的实例在后端提供了两个节点,正常情况下某一时刻只由主节点(下图中的节点A)提供读写服务,而备节点(下图中的节点B)负责数据同步;当A发生(硬件)故障时, HA控制器(代号:AURORA)会在30秒内将服务切换到B节点上面,通过这种机制来保证数据库实例的高可用性。

rds-2-1

RDS 简易链路访问图

进行主备切换后,真正生效的服务节点为B。为了主备切换对用户和应用透明,我们使用VIP技术来提供数据服务。用户在程序里只要配置VIP地址,不管后端节点切换到哪里,都不需要变更数据库连接地址,即可继续与数据库服务建立会话并完成请求。

虽然RDS在发生主备切换后,应用程序与数据库可以建立新会话(SESSION),但在切换前APP与RDS建立好的会话(保存在A节点)已经断开,对程序来说这部分会话已经失效,这时候需要程序有能力重新建立会话以恢复正常请求。

RDS 闪断,是指APP与RDS之间的网络链路在短时间内(一般不超过三十秒)发生了中断,需要应用重新建立连接即可恢复;虽然是通过VIP提供服务,但APP与数据库的连接是保存在A节点上面,在发生切换后,APP与A节点建立的物理链接也会被中断,导致APP需要与B节点重新建立链接;这就是闪断发生的整个过程。

 

如何应对“闪断”

 

处理闪断其实很简单,有两种常见方法:

1)  使用“短连接”模式向数据库发起请求

短连接模式,是指与数据库建立会话后,只进行一次请求,完成后该会话即被关闭;

不过短连接模式下,每个请求都需要向数据库认证账号与密码,每个认证过程至少6次网络交互,效率较低;适合于请求量较小的应用或网站采用。

 

2)  配置连接池,使其消除掉有问题的连接(推荐模式)

大多数连接池均包含链接有效性探测,适当配置后即可消除连接闪断对应用的影响,比如适用于JAVA语言的CP30、DBCP、Druid等连接池,均可通过以下几个参数设置(需要充分测试以确定可能的性能开销):

<property value=”SELECT 1″ name=”validationQuery”></property><property value=”true” name=”testWhileIdle”></property>

<property value=”true” name=”testOnBorrow”></property>

<property value=”true” name=”testOnReturn”></property>

 

当然技术总是需要不断进步的。RDS 内核团队正在研究一种”桥接”技术,当发生节点A到节点B的切换时,可以自动让APP与节点B建立连接,做到对APP完全透明。该技术成功突破后,数据库的重连机制会由底层统一实现,不再需要大家去重复敲相同的代码,那将是开发者的一大福音。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8月前
|
SQL 人工智能 算法
【SQL server】玩转SQL server数据库:第二章 关系数据库
【SQL server】玩转SQL server数据库:第二章 关系数据库
184 10
|
2天前
|
运维 关系型数据库 MySQL
体验领礼啦!体验自建数据库迁移到阿里云数据库RDS,领取桌面置物架!
「技术解决方案【Cloud Up 挑战赛】」上线!本方案介绍如何将自建数据库平滑迁移至云数据库RDS,解决业务增长带来的运维难题。通过使用RDS MySQL,您可获得稳定、可靠和安全的企业级数据库服务,专注于核心业务发展。完成任务即可领取桌面置物架,每个工作日限量50个,先到先得。
|
20天前
|
运维 关系型数据库 MySQL
自建数据库迁移到云数据库RDS
本次课程由阿里云数据库团队的凡珂分享,主题为自建数据库迁移至云数据库RDS MySQL版。课程分为四部分:1) 传统数据库部署方案及痛点;2) 选择云数据库RDS MySQL的原因;3) 数据库迁移方案和产品选型;4) 线上活动与权益。通过对比自建数据库的局限性,介绍了RDS MySQL在可靠性、安全性、性价比等方面的优势,并详细讲解了使用DTS(数据传输服务)进行平滑迁移的步骤。此外,还提供了多种优惠活动信息,帮助用户降低成本并享受云数据库带来的便利。
|
5月前
|
关系型数据库 MySQL 数据库
RDS MySQL灾备服务协同解决方案构建问题之数据库备份数据的云上云下迁移如何解决
RDS MySQL灾备服务协同解决方案构建问题之数据库备份数据的云上云下迁移如何解决
|
1月前
|
安全 关系型数据库 MySQL
体验自建数据库迁移到云数据库RDS,领取桌面置物架!
「技术解决方案【Cloud Up 挑战赛】」正式开启!本方案旨在帮助用户将自建数据库平滑迁移至阿里云RDS MySQL,享受稳定、高效、安全的数据库服务,助力业务快速发展。完成指定任务即可赢取桌面置物架等奖励,限量供应,先到先得。活动时间:2024年12月3日至12月31日16点。
|
8月前
|
SQL 算法 数据库
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
437 6
|
5月前
|
SQL 关系型数据库 数据库
数据库空间之谜:彻底解决RDS for SQL Server的空间难题
【8月更文挑战第16天】在管理阿里云RDS for SQL Server时,合理排查与解决空间问题是确保数据库性能稳定的关键。常见问题包括数据文件增长、日志文件膨胀及索引碎片累积。利用SQL Server的动态管理视图(DMV)可有效监测文件使用情况、日志空间及索引碎片化程度。例如,使用`sp_spaceused`检查文件使用量,`sys.dm_db_log_space_usage`监控日志空间,`sys.dm_db_index_physical_stats`识别索引碎片。同时,合理的备份策略和文件组设置也有助于优化空间使用,确保数据库高效运行。
128 2
|
5月前
|
关系型数据库 数据库 数据安全/隐私保护
"告别繁琐!Python大神揭秘:如何一键定制阿里云RDS备份策略,让数据安全与效率并肩飞,轻松玩转云端数据库!"
【8月更文挑战第14天】在云计算时代,数据库安全至关重要。阿里云RDS提供自动备份,但标准策略难以适应所有场景。传统手动备份灵活性差、管理成本高且恢复效率低。本文对比手动备份,介绍使用Python自定义阿里云RDS备份策略的方法,实现动态调整备份频率、集中管理和智能决策,提升备份效率与数据安全性。示例代码演示如何创建自动备份任务。通过自动化与智能化备份管理,支持企业数字化转型。
120 2
|
5月前
|
存储 C# 关系型数据库
“云端融合:WPF应用无缝对接Azure与AWS——从Blob存储到RDS数据库,全面解析跨平台云服务集成的最佳实践”
【8月更文挑战第31天】本文探讨了如何将Windows Presentation Foundation(WPF)应用与Microsoft Azure和Amazon Web Services(AWS)两大主流云平台无缝集成。通过具体示例代码展示了如何利用Azure Blob Storage存储非结构化数据、Azure Cosmos DB进行分布式数据库操作;同时介绍了如何借助Amazon S3实现大规模数据存储及通过Amazon RDS简化数据库管理。这不仅提升了WPF应用的可扩展性和可用性,还降低了基础设施成本。
103 0
|
6月前
|
消息中间件 关系型数据库 数据库
实时计算 Flink版操作报错合集之在使用RDS数据库作为源端,遇到只能同步21个任务,是什么导致的
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。

推荐镜像

更多