客户说|PolarDB最佳实践:东南亚独角兽Akulaku云原生数据库架构演进之路

本文涉及的产品
云原生数据库 PolarDB 分布式版,标准版 2核8GB
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介: 东南亚独角兽Akulaku云原生数据库架构演进之路

1.引言

云数据库实现了计算存储分离,支持计算与存储的独立扩展,高可用性和灵活性,同时提供按量计费,增强成本的可控性,因此应用已非常普遍。但各家云数据库也有会各自的特性与瓶颈,比如传统的类MySQL云数据库服务在面对几亿甚至几十亿数据量变更时,会显得十分吃力,影响业务迭代速度。我司在调研解决此问题时对阿里云原生数据库PolarDB有所研究与实践,通过本文做一分享,希望能够为行业提供一些参考。


2.背景

Akulaku是一家领先的金融科技公司,为东南亚市场提供数字金融解决方案。随着公司的快速发展,业务量的持续增加,部分采用传统的数据库服务已不能满足业务增长需求。这些业务拥有数百套的数据库,在日常工作中数据库的扩容,以及在高负载下频繁的数据变更 ,维护成本上升较快,因此我们决定投入资源调研方案以解决此问题。


针对目前传统云数据库面临的问题,主要包括以下几个方面:

1.核心数据库负载普遍较高,对于高负载能力不足,同时节点扩容不便,而且读写常常都配置在主库。

2.日常变更,超过一亿行大表变更变得越来越多,对数据库性能和业务影响较大。

3.主从延时,因为延迟导致从库接口查不到数据而报错。

4.磁盘容量上限,不足以支持业务数据扩展。


经过收集业务痛点和数据库架构综合选型,我们最终决定把该部分业务迁移到PolarDB上,原因在于PolarDB的计算节点和共享存储分离,便于快速扩展,底层使用物理日志,主从同步在毫秒级,以及支持100T的超大磁盘容量,让业务不需要担心磁盘空间问题,同时在测试中PolarDB的性能和容灾方面也有很出色的表现。


架构改动,如图:

1.JPG

3.迁移

下面介绍从传统云数据库至PolarDB的迁移环节。整个迁移主要由4个阶段组成:


  • 原数据库信息收集,用于判断是否满足迁移需求
  • 针对不同业务编写迁移方案
  • 数据同步和迁移过程的保障
  • 迁移后的成果验收和性能表现

2.JPG


3.1 业务梳理

收集需要迁移的数据库实例,我们主要围绕日常变更频繁和性能优化较大的实例。对于迁移方案,需要结合实际情况调研,比如不仅需考虑主业务本身,还需考虑上下游业务,例如数据分析平台,数仓报表,Canal同步等。


3.2 上下游异构数据

依赖业务需要在主业务迁移前先迁移到PolarDB,避免主业务迁移后,出现依赖业务数据缺失的情况。特别是异构数据源的场景,这里以Canal迁移为例:

3.JPG

Canal需要提前切换到PolarDB上,这里需要注意两个问题。

1. 切换PolarDB时,因为binlog的位点信息变更,需要提前修改好Canal的配置文件。

2. 确认PolarDB上对应Canal的同步账号,权限和密码是否和原数据库上的一致。


3.3 自动化运维平台

由于业务日常变更量大,Akulaku自主研发数据库运维平台,集成实例迁移,SQL审核,系统巡检等功能。本次迁移主要依赖数据库自动化平台的实例迁移功能,同时能避免误操作造成的业务影响。切换完后,也可以根据平台的资源展示和监控功能,实时查看PolarDB的性能状态。

4.JPG

数据库自动化运维平台的数据同步功能,主要是调用了DTS接口来做数据的实时同步,只需要在平台上填好配置即可,后面的账号迁移和域名变更都是通过平台一键操作。


要注意几个事项:

1. 数据同步时需要确认源端是否有触发器,可能会导致源和目标数据不一致,需要删除被迁移到目标库中的触发器。2. 域名切换前确保依赖业务已经全部迁移到PolarDB,防止依赖业务数据丢失。

3. 域名切换前确保业务无写入,避免业务双写。


3.4 迁移结果验收

本章节对迁移后的情况做一介绍,同时探讨一下PolarDB相关的相关特性。


3.4.1 性能优势

随着业务量上涨,在电商大促的场景,能体验到迁移后带来的好处。比如我们有一个数据库的QPS有几十万,以前数据库做支撑明显感觉到吃力,而且有些业务读写都在主库,加大对主库的负载压力。


PolarDB 计算节点和存储分离,能快速扩充计算节点,能更好地应付突发情况。自带Proxy节点,可以支持读写分离和业务切割,负载均衡,能更好地应付高负载的环境。

5.PNG


在大促高负载的场景下,我们收集了一些QPS和往年的数据库做了对比,看到PolarDB性能有明显的提升。在相同配置下,数据库负载越高,PolarDB的优势越大,优势不仅仅是性能上的优化,同时也体现在数据库的稳定性上。


PolarDB的功能特点

1. 读写分离

因为业务没有做读写分离,常常把连接都打到主库。而PolarDB只需要提供集群地址, 在保证读写一致性的前提下,对一些读写的事务,自动分流到主从库上,而且基于负载的自动调度策略,按照活跃连接数自动调度,实现多个节点间的负载均衡。

2. 快速添加从节点

在一些大促期间,某些从库负载瞬时飙升,导致业务查询过慢。这时PolarDB可以快速添加从节点。因为PolarDB是共享的磁盘,添加节点不需要拷贝数据。另外计算节点和存储分离,单独添加从节点时,不影响整个集群的运行。

3. 高速链路互联

一般MySQL的服务针对单个服务器,数据从写入到落盘,都是要经过OS的缓存的,即OS内核和用户数据的交互。PolarDB采用远程直接数据存取(Remote Direct Memory Access,以下简称RDMA)高速网络互连的众多区块服务器(Chunk Server)一起向上层计算节点提供块设备服务。摆脱传统的io模式,让数据读写更上一层楼,QPS可突破50w。


3.4.2 日常大表变更

对于大表加列,特别是涉及到数据分析平台的业务,表的基数都特别大,亿级别的表不在少数。以往在MySQL做变更时,为了把业务影响降低到最小,一般都是使用的PT或者Ghost工具进行大表的变更。但是耗时很长,而且常常会因为网络或者负载原因中断。迁移到PolarDB后,对于那些大表加列的DDL变更,现在可以直接通过自动化平台操作,利用PolarDB的新特性直接添加。


PolarDB 5.7入了MySQL 8.0的新特性—Instant Add Column ,快速加列采用的是 instant 算法,使得添加列时不再需要 rebuild 整个表,只需要短暂的获取MDL锁并在表的 metadata 中记录新增列的基本信息即可。而对于加索引, PolarDB支持并行DDL和DDL物理复制优化功能。


秒级加字段

6.PNG

如上图所示,一亿多的大表,加列变更时,耗时都是在1秒内完成, 只需变更表定义信息,无需修改已有数据。基于该特性,大大降低业务变更时间和风险,对于我们日常维护有巨大的帮助,提升数据库SLA。

7.PNG

由上图可知,在添加列时,PolarDB耗时一直稳定在1秒内,但是原MySQL数据库的耗时却随着数据量的增长而增长。特别是几亿行的表变更时,原数据库耗时需要十几个小时。PolarDB执行效率有明显的提升,对比起来有质的飞跃。


针对PolarDB MySQL引擎5.7版本的集群,需要开启以下参数来使用秒级加字段功能:

innodb_support_instant_add_column


并行创建索引

8.PNG

9.PNG

如上图所示,包含4.4亿行数据、接近3TB大小的表,使用并行创建索引,只用了不到20分钟的时间,极大地缩短了大表创建索引的耗时。

10.PNG

由上图可见,与原MySQL对比,随着表的大小的提升,PolarDB创建索引的性能优势越来越明显。


3.4.3 主从延迟

对于Akulaku业务系统,有一些业务场景对于主从延时要求特别严格。在使用原MySQL数据库时,往往因为延迟而触发业务告警,也是我们比较头疼的一个问题。迁移到PolarDB后,主从同步的效率有明显的提升。


PolarDB采用物理日志进行同步,因为共享存储原因,主节点通过RDMA网络将数据实时更新到共享存储,其它计算节点通过高性能的RDMA网络实时读取redo日志去修改Buffer Pool中的Page,同步B+Tree及事务信息。不同于逻辑复制自上而下的复制方式,物理复制方式是自下而上的,能把主要延时控制在毫秒级别。


物理同步

11.PNG

如架构图所示,Primary和Replica节点共享同一个PFS(PolarStore File System),复用数据文件和日志文件,RO节点直接读取PFS上的Redo Log进行解析,并将其修改应用到自己Buffer Pool中的Page上,当用户的请求到达Replica节点后,就可以访问到最新的数据了。同时Replica和Primary节点间也会保持RPC通信,用于同步Replica当前日志的Apply位点,以及ReadView等信息。


3.4.4 磁盘容量随着业务量增长,原MySQL数据库服务的磁盘需频繁进行扩容操作,对于一些区域磁盘剩余不足的情况,还会导致实例切换,严重影响业务。数据分析平台相关业务,存储的数据至少都是T级别,而PolarDB可以支持到100T的容量,较大程度上缓解了这个问题,由于其底层的架构的优化,在IO性能方面得到较大的提升。PolarDB的存储是怎么样做到高容错,容量大,而且加载速度快的?我们查询了相关资料,了解到这是PolarFS起了作用,如感兴趣可参阅以下文档:

https://www.vldb.org/pvldb/vol11/p1849-cao.pdf


4.结语

12.PNG

初步统计,本次迁移跨公司多个业务线,涉及系统有几十个,从开始调研到最后正式上线耗时数月。经过大半年的实践,稳定性、兼容性、性能等均符合预期,能够满足我们现阶段发展需求。期望阿里云以后可以推出更多好的产品,共同迎接未来的挑战。


 / End /  

相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
7天前
|
Kubernetes Cloud Native 微服务
探索云原生技术:容器化与微服务架构的融合之旅
本文将带领读者深入了解云原生技术的核心概念,特别是容器化和微服务架构如何相辅相成,共同构建现代软件系统。我们将通过实际代码示例,探讨如何在云平台上部署和管理微服务,以及如何使用容器编排工具来自动化这一过程。文章旨在为开发者和技术决策者提供实用的指导,帮助他们在云原生时代中更好地设计、部署和维护应用。
|
6天前
|
运维 Cloud Native 持续交付
云原生技术深度探索:重塑现代IT架构的无形之力####
本文深入剖析了云原生技术的核心概念、关键技术组件及其对现代IT架构变革的深远影响。通过实例解析,揭示云原生如何促进企业实现敏捷开发、弹性伸缩与成本优化,为数字化转型提供强有力的技术支撑。不同于传统综述,本摘要直接聚焦于云原生技术的价值本质,旨在为读者构建一个宏观且具体的技术蓝图。 ####
|
6天前
|
Cloud Native API 持续交付
云原生架构下的微服务治理策略与实践####
本文旨在探讨云原生环境下微服务架构的治理策略,通过分析当前面临的挑战,提出一系列实用的解决方案。我们将深入讨论如何利用容器化、服务网格(Service Mesh)等先进技术手段,提升微服务系统的可管理性、可扩展性和容错能力。此外,还将分享一些来自一线项目的经验教训,帮助读者更好地理解和应用这些理论到实际工作中去。 ####
17 0
|
7天前
|
Cloud Native 持续交付 云计算
云原生架构的崛起:企业数字化转型的加速器
在当今快速发展的技术环境中,企业正面临着前所未有的变革压力。本文深入探讨了云原生架构如何成为推动企业数字化转型的关键力量。通过分析其核心概念、优势以及实施策略,本文旨在为读者提供对云原生技术的全面理解,展示其在现代企业中不可或缺的作用。
15 0
|
3天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
45 15
|
4天前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。
|
8天前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
16天前
|
关系型数据库 MySQL 数据库
GBase 数据库如何像MYSQL一样存放多行数据
GBase 数据库如何像MYSQL一样存放多行数据
|
28天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
34 1
|
1月前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
39 4

相关产品

  • 云原生数据库 PolarDB