阿里云RDS vs 自建MySQL,这篇评测终结你的选择困难症!

本文涉及的产品
云原生数据库 PolarDB MySQL 版,Serverless 5000PCU 100GB
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 云,为IT基础设施的构建带来很大的便利性。数据库,作为云中非常重要的一类产品,正有越来越多的客户选择使用。但在使用云端数据库时,经常有两类做法:一是通过ECS自建数据,二是直接使用云提供的数据库产品。那么这两类做法,有什么差异?用户又该如何选择呢?

本文作者:韩锋,阿里云数据库高级产品专家

云,为IT基础设施的构建带来很大的便利性。数据库,作为云中非常重要的一类产品,正有越来越多的客户选择使用。但在使用云端数据库时,经常有两类做法:一是通过ECS自建数据,二是直接使用云提供的数据库产品。那么这两类做法,有什么差异?用户又该如何选择呢?

下面通过在阿里云平台的一组测试,给你带来答案!

1. 测试概述

本测试对比了阿里云中ECS自建数据库(5.7/8.0版本)和RDS通用实例,在OLTP读写混合模型下的性能。测试使用了标准的sysbench 1.0工具,选择规格是用户最普遍使用的4核16GB规格数据库,其中innodb_buffer_pool_size =12G。

1).测试场景

一共测试了3个场景,分别为:

  • 内存命中型(CPU先到达瓶颈)150张表,每张表25000行数据,数据量大约2GB。
  • 小规模IO型(CPU先到达瓶颈)150张表,每张表120万行数据,数据量大约50GB。
  • 大规模IO型(IOPS先到达瓶颈)150张表,每张表500万行数据,数据量大约200GB。

2).测试结论

  • 在CPU先到达瓶颈的场景下,RDS通用实例相比于ECS本地盘自建,性能优势比较大。
  • 在IOPS先到达瓶颈的场景下,RDS通用实例相比于ECS本地盘自建,性能优势不大。
  • 在3个场景中,RDS通用实例相比于ECS本地盘自建,均有一定的性能优势,且整体表现稳定。

2. 测试环境

测试环境.jpg

  • ECS自建环境的MySQL,采用了主从架构。
  • RDS采用4C 16GB,本地SSD,高可用版通用型,主从架构。
  • ECS自建MySQL与RDS,使用了相同的配置模板。

3. 测试数据(场景:内存命中型)

1).MySQL5.7 高性能模板

3.1.png

  • 在不同并发条件下,RDS均较ECS自建MySQL性能更优。
  • 在低并发(并发度=16)条件下,RDS性能表现更为突出。其QPS指标比ECS本地盘高87%。
  • 开源MySQL没有线程池功能,高并发下抖动大。

2).MySQL8.0 高性能模板

3.1.2.png

  • 在不同并发条件下,RDS均较ECS自建MySQL性能更优。
  • 在低并发(并发度=16)条件下,RDS性能表现更为突出。其QPS指标比ECS本地盘高70%。
  • 开源MySQL没有线程池功能,高并发下抖动非常大,基本处于不可用状态。

4. 测试数据(场景:小规模IO型)

1).MySQL5.7 高性能模板

3.2.1.png

  • 在不同并发条件下,RDS均较ECS自建MySQL性能更优。
  • 在低并发(并发度=16)条件下,RDS性能表现更为突出。其QPS指标比ECS本地盘高107%。
  • 开源MySQL没有线程池功能,高并发下抖动非常大。

2).MySQL8.0 高性能模板

3.2.2.png

  • 在不同并发条件下,RDS均较ECS自建MySQL性能更优。
  • 在低并发(并发度=16)条件下,RDS性能表现更为突出。其QPS指标比ECS本地盘高82%。
  • 开源MySQL没有线程池功能,高并发下抖动非常大,基本处于不可用状态。

❖ CPU先达到瓶颈

iops.png

  • 16个并发时,RDS的cpu开始打满。整个压测过程中,IOPS并未到达瓶颈。
  • ECS本地盘的监控信息显示,读和写的IOPS一直在3000左右,峰值读3000,写6000左右。

5. 测试数据(场景:大规模IO型)

1).MySQL5.7 高性能模板

3.3.1.png

  • 在不同并发条件下,RDS均较ECS自建MySQL性能占优。
  • 因为RDS的IOPS先到达瓶颈。整个压测过程中,RDS的QPS相对于ECS本地盘的优势不是太大,高10%左右。
  • 读写IOPS较大,ECS+ESSD云盘的性能劣势可以体现出来。
  • 开源MySQL没有线程池功能,高并发下抖动非常大。

❖ IO先达到瓶颈

3.3.11.png

  • 压测过程中,RDS的cpu未用满。IOPS到达瓶颈,物理读维持在6000左右。

iops.png

  • ECS本地盘,IOPS超过了RDS的使用限额(7000)。
  • ECS的CPU可以用满。

2).MySQL8.0 高性能模板

3.3.2.png

  • RDS在IO压力很大下,性能表现依然平稳。
  • 因RDS的IOPS先到达瓶颈。压测过程中,RDS的QPS相对于ECS本地盘的优势没有上一场景大。
  • 读写IOPS较大,ECS+ESSD云盘的性能劣势凸显,衰减严重。
  • 开源MySQL8.0在高IO情况下,性能退化严重。

6. 从测试中获得...

通过上述测试数据可以看出,RDS较ECS自建模式在性能表现上更为出色。这主要是基于云厂商多年在数据库领域的实践深度优化所得。当然,用户在做选择时,不能仅仅依据性能表现,而应该基于更多维度考量。下表简列一二,供各位参考。

对比.jpg

  • RDS本身具有极高的可用性,自建方式需用户维护。
  • 外围功能(例监控、备份、优化等),自建方式需用户构建。
  • 自建方式的自主性较大,用户可定制化自身需求。

BTW:如何获得高性能参数模板

在购买RDS步骤“实例配置”中,可在如下位置选择“高性能参数模板”

param.png

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
30天前
|
存储 关系型数据库 MySQL
RDS MySQL 数据库运维简述
从运维的视角,汇总云数据库RDS MySQL使用的避坑指南。文章初版,维护更新,欢迎指点。
761 3
|
26天前
|
SQL 关系型数据库 MySQL
阿里云MySQL数据库价格、购买、创建账号密码和连接数据库教程
阿里云数据库使用指南:购买MySQL、SQL Server等RDS实例,选择配置和地区,完成支付。创建数据库和账号,设置权限。通过DMS登录数据库,使用账号密码访问。同地域VPC内的ECS需将IP加入白名单以实现内网连接。参考链接提供详细步骤。
366 3
|
1月前
|
弹性计算 关系型数据库 MySQL
阿里云ECS使用docker搭建mysql服务
阿里云ECS使用docker搭建mysql服务
151 1
|
1月前
|
弹性计算 缓存 测试技术
阿里云ECS云服务器2核4G能支持多少人同时访问?2核4G5M并发量评测
阿里云ECS云服务器2核4G能支持多少人同时访问?2核4G5M并发量评测,2核4G服务器并发数性能测试,阿小云账号下的2核4G服务器支持20人同时在线访问,然而应用不同、类型不同、程序效率不同实际并发数也不同,2核4G服务器的在线访问人数取决于多个变量因素
|
26天前
|
弹性计算 关系型数据库 MySQL
阿里云MySQL云数据库优惠价格、购买和使用教程分享!
阿里云数据库使用流程包括购买和管理。首先,选购支持MySQL、SQL Server、PostgreSQL等的RDS实例,如选择2核2GB的MySQL,设定地域和可用区。购买后,等待实例创建。接着,创建数据库和账号,设置DB名称、字符集及账号权限。最后,通过DMS登录数据库,填写账号和密码。若ECS在同一地域和VPC内,可内网连接,记得将ECS IP加入白名单。
419 2
|
27天前
|
SQL 关系型数据库 MySQL
阿里云mysql数据库价格购买和使用教程
阿里云数据库使用指南:购买MySQL、SQL Server等RDS实例,通过选择配置、地域和可用区完成购买。创建数据库和账号,分配权限。使用DMS登录数据库,进行管理操作。确保ECS与RDS在同一地域的VPC内,配置白名单实现内网连接。详细步骤见官方文档。
626 1
|
28天前
|
供应链 安全 专有云
阿里云通过信通院面向一云多芯的专有云技术能力评测
近日,阿里云飞天企业版通过中国信息通信研究院2023年度《面向一云多芯的专有云技术能力要求》,在异构兼容能力、专有云基础能力、迁移适配能力三个方面,再一次验证了阿里云专有云一云多芯领先的技术能力。
|
28天前
|
关系型数据库 MySQL Serverless
RDS MySQL Serverless
阿里云新推出RDS MySQL Serverless,提供实时弹性资源,按需设置范围,自动适应负载变化,实现资源优化与成本降低。用户可通过控制台或API轻松创建实例,无缝应对低负载至高负载场景,实现自动弹性扩缩容。该服务适合各种云数据库应用场景,兼具成本优化和高灵活性。【2月更文挑战第29天】
32 1
|
29天前
|
关系型数据库 MySQL 数据库
使用阿里云的数据传输服务DTS(Data Transmission Service)进行MySQL 5.6到MySQL 8.0的迁移
【2月更文挑战第29天】使用阿里云的数据传输服务DTS(Data Transmission Service)进行MySQL 5.6到MySQL 8.0的迁移
216 2
|
30天前
|
弹性计算 文件存储 数据库
阿里云8M带宽云服务器承载量多大?阿里云8M带宽云服务器评测
在当今的云计算时代,云服务器已成为企业和个人用户的首选。其中,带宽作为衡量云服务器性能的重要指标之一,经常被人们提及。那么,一个拥有8M带宽的云服务器到底能承受多少承载量呢? 我们以常见的网站应用为例来探究这个问题。假设经过优化后的网页平均大小为60KB,8M带宽即意味着每秒能传输8*1024KB的数据。简单计算可知,8M带宽的云服务器在1秒内可以传输大约136个这样的网页。但是,这并不意味着它能同时支持136个用户访问,因为还需要考虑用户访问的并发性。
97 1

相关产品

  • 云数据库 RDS MySQL 版