目录
在不同的云厂商,购买相同规格的MySQL实例(如4vCPU-16GB),获得的性能相同吗?该专题系列,通过对不同云厂商的同样规格进行测试,尝试回答该问题。
2024年05月 云数据库RDS MySQL性能测试趋势图
测试概述
关于测试更多详细说明:云数据库MySQL性能测试@2024年05月
测试中如何选择各个云厂商的“标准4c16g”实例:参考该文章中各个云厂商小结的说明
性能表现的部分原因分析可以参考:《云数据库(RDS MySQL)性能深度测评与对比》
theads/qps | Aliyun_HZ | AWS | Azure | Baidu | GCP | Huawei | Oracle | Tencent |
---|---|---|---|---|---|---|---|---|
4 | 4649 | 3607 | 1716 | 2157 | 1428 | 2623 | 3773 | 5783 |
8 | 7509 | 6821 | 3050 | 4041 | 2551 | 4770 | 5557 | 10157 |
16 | 10951 | 12470 | 5579 | 7041 | 4686 | 8694 | 8403 | 16557 |
32 | 13586 | 18022 | 9352 | 11816 | 8042 | 14192 | 8166 | 22970 |
48 | 15312 | 21092 | 12148 | 16049 | 10017 | 17621 | 8009 | 26083 |
64 | 15831 | 22540 | 13516 | 18554 | 10837 | 19927 | 7901 | 27886 |
96 | 16565 | 24937 | 14672 | 20378 | 11622 | 20555 | 8092 | 30337 |
128 | 16996 | 25214 | 15210 | 20135 | 12112 | 20151 | 8089 | 31355 |
192 | 17387 | 25296 | 15498 | 20915 | 12027 | 20648 | 7865 | 32323 |
256 | 17501 | 25390 | 15419 | 21098 | 12403 | 21796 | 7851 | 32582 |
384 | 17494 | 25313 | 15487 | 21131 | 12361 | 22957 | 7804 | 32803 |
512 | 18120 | 24975 | 15582 | 21204 | 12379 | 23177 | 7958 | 32962 |
关于该测试
一直都在非常深度调研、关注和使用云数据库,其中性能是关注的重点之一。一方面性能是最终成本的重要影响因素,更好的性能,通常意味着使用更少的资源支撑更高的业务量,从而降低整体成本。另外,性能还意味着在极端场景下,数据库的上限支撑能力。所以,一直以来都会持续的对RDS MySQL的不同厂商、规格进行性能测试,在此汇总相关数据,供开发者和企业在云数据库选型时的参考。
其他实用结论(TL;DR)
先说些一些基于测试的实用结论吧,可以让更多的开发者参考:
- 不同的云厂商,有着不同的存储架构,不同的安全性/性能考虑,不同的CPU类型/多寡等,看似相同的规格,性能却有着巨大的差异
- 在阿里云上,强烈建议考虑使用经济版(ARM)替换标准版(x86),很容易获得超30%的性价比(参考)
- 总是建议使用最新一代CPU实例,通常都可以获得15%的性价比提升,例如AWS m6i vs m5i,m7g vs m6g(参考)
- 几大云厂商的”企业级”实例的性能有着显著差异,主要原因是主从复制架构、CPU代差、存储架构等不同导致(参考)
- 国内云厂商都提供了“通用型”实例,以非常小的资源共享换取了非常大的性价比提升,非常适合非关键场景使用(参考)
第一次云数据库性能测试
ARM vs x86 @RDS MySQL
整体上,在不同的平台上ARM-based的RDS MySQL有着不同的表现。具体如下:
Graviton vs x86 on AWS
- 在AWS上,Graviton 3实例RDS性能在高并发时,相对x86有较明显的性价比优势,以128并发为例,m7g vs m6i的对比
- Graviton 3 相比Graviton 2有非常明显的性能优势(参考),这与宣称的27%性价比提升是较为一致的
- Graviton 2实例相比x86几乎没有什么优势,与宣称的52%性价比提升结果相悖
ARM vx x86 on 阿里云
- 经济版(ARM)比标准版(x86)性价比要高出32%
- 具体的:选取16并发,ARM版TPS为2185,x86版TPS为2324。价格上, ARM版价格为1.61元/时, x86版价格为2.52元/时,那么对应每1000个TPS的价格分别为:0.74元与1.08元。从性价比的角度来看,经济版提升了31.5%
鲲鹏 vs x86 on 华为云
- x86和鲲鹏架构实例价格是相同的
鲲鹏版本相比x86约有15~45%的性能差距 - 考虑到自研鲲鹏芯片在中国自主可控芯片中的地位,在国内大量无法使用x86的场景中,这个性能下降通常都是可以接受
启用TLS对RDS MySQL的性能影响
开启传输加密时,对性能的影响约为2%~8%,不同的环境不同的数据库版本会有一些不同。在实际的生产环境中,建议默认打开该功能,应用连接是否需要开启,可以根据实际场景决定。通常,如果Client端和数据库服务器不再同一个网络环境中,则建议Client端启用加密传输。
云数据库性能测试@ACMUG(中国MySQL用户组)
如下是本人在2024年1月的ACMUG(中国MySQL用户组)大会上的分享内容,较为详细对之前的云数据库 RDS MySQL性能测试做了分享。如下为分享的PDF,供参考:
关于测试方法的说明(概述)
这里使用常用的、易用重现的Sysbench工具进行测试。主要的模型包括oltp_read_write以及部分自定义模型。Sysbench因为其易用使用,可定制性高被业绩广泛使用,包括AWS、Google Cloud、阿里云、腾讯云等。
sysbench oltp_read_write模型
sysbench的oltp_read_write模型是一个事务压测模型,单个事务中包含了10个点查、4个范围查询(包括了ORDER BY/SUM/DISTINCT等)、影响索引的更新、不影响索引的更新、删除数据、插入数据。具体的,SQL示例如右侧代码所示。
关于该测试模型的详细说明可以参考文章:
- Sysbench oltp_read_write负载下运行的是什么SQL
- Sysnbench oltp_read_write.lua@GitHub
- Sysbench压测中出现”Duplicate entry”的原因
- Sysbench使用hook以及其性能影响
oltp_read_write模型的Queries
BEGIN
SELECT c FROM sbtest3 WHERE id=5025
SELECT c FROM sbtest3 WHERE id=5010
SELECT c FROM sbtest3 WHERE id=5004
SELECT c FROM sbtest3 WHERE id=5019
SELECT c FROM sbtest3 WHERE id=5027
SELECT c FROM sbtest3 WHERE id=5020
SELECT c FROM sbtest3 WHERE id=4326
SELECT c FROM sbtest3 WHERE id=5044
SELECT c FROM sbtest3 WHERE id=6045
SELECT c FROM sbtest3 WHERE id=3529
SELECT c FROM sbtest3 WHERE id BETWEEN 5020 AND 5119
SELECT SUM(k) FROM sbtest5 WHERE id BETWEEN 5010 AND 5109
SELECT c FROM sbtest3 WHERE id BETWEEN 5000 AND 5099 ORDER BY c
SELECT DISTINCT c FROM sbtest4 WHERE id BETWEEN 5039 AND 5138 ORDER BY c
UPDATE sbtest4 SET k=k+1 WHERE id=4291
UPDATE sbtest1 SET c='57995045141-...-55126207842' WHERE id=5022
DELETE FROM sbtest4 WHERE id=4999
INSERT INTO sbtest4 (id, k, c, pad) VALUES (4999, 5049, '77394423405-...-74420299847', '43459108876-...-51424111535')
COMMIT
Leave a Reply