阿里云原生数据库POLARDB压力测试报告

POLARDB介绍

POLARDB是阿里云ApsaraDB数据库团队研发的基于云计算架构的下一代关系型数据库,其最大的特色是计算节点(主要做SQL解析以及存储引擎计算的服务器)与存储节点(主要做数据块存储,数据库快照的服务器)分离,其次,与传统的云数据库一个实例一份数据拷贝不同,同一个实例的所有节点(包括读写节点和只读节点)都访问存储节点上的同一份数据,最后,借助优秀的RDMA网络以及最新的块存储技术,PolarDB的数据备份耗时可以做到秒级别(备份时间与底层数据量无关),这三点相结合,我们可以推断出POLARDB不但满足了公有云计算环境下用户业务快速弹性扩展的刚性需求(只读实例扩展时间与底层数据量无关),同时也满足了互联网环境下用户对数据库服务器高可用的需求(服务器宕机后无需搬运数据重启进程即可服务)。

以下测试来自于袋鼠云技术部。

POLARDB架构

一写多读

POLARDB采用分布式集群架构,一个集群包含一个主实例和至少一个只读实例(暂时仅支持一个,用于保障高可用)。主实例处理读写请求,只读实例仅处理读请求。主实例和只读实例之间采用Active-Active的Failover方式,提供数据库的高可用服务。

计算与存储分离

POLARDB采用计算与存储分离的设计理念,满足公有云计算环境下用户业务弹性扩展的刚性需求。数据库的计算节点(DB Server)仅存储元数据,而将数据文件、Redo Log等存储于远端的存储节点(Chunk Server)。各计算节点之间仅需同步Redo Log相关的元数据信息,极大降低了主实例和只读实例间的延迟,而且在主实例故障时,只读实例可以快速切换为主服务器。

读写分离

读写分离数据库接入功能,是POLARDB集群默认免费提供的一个透明、高可用、自适应的负载均衡能力。通过读写分离地址,SQL请求自动转发到POLARDB集群的各个实例,提供聚合、高吞吐的并发SQL处理能力。

高速链路互联

数据库的计算节点和存储节点之间采用高速网络互联,并通过RDMA协议进行数据传输,使得I/O性能不再成为瓶颈。

共享分布式存储

多个计算节点共享一份数据,而不是每个计算节点都存储一份数据,极大降低了用户的存储成本。基于全新打造的分布式块设备和文件系统,存储容量可以在线平滑扩展,不会受到单机服务器配置的影响,可应对上百TB级别的数据规模。

数据多副本、Parallel-Raft协议

数据库存储节点的数据采用多副本形式,确保数据的可靠性,并通过Parallel-Raft协议保证数据的一致性。
优点:
备份速度快,增加只读节点速度快。
只读实例无延迟。

参数
POLARDB默认关闭了doublewrite buffer,关闭了binlog。

压测方案

使用sysbench oltp标准压测程序分别压测读、写两种场景的性能。

环境准备
PolarDB: 8C64G
ECS:2C2G, CentOS 2.7(三台)
Sysbench 0.5

sysbench安装
yum -y install mysql-devel 

yum -y install automake 

yum -y install libtool 

wget https://github.com/akopytov/sysbench/archive/0.5.zip
unzip 0.5.zip
cd sysbench-0.5
./autogen.sh
./configure
make
cd sysbench

压测步骤

准备数据
sysbenchpath/sysbench−−test=sysbench_path/tests/db/oltp.lua --mysql-host=ip−−mysql−port=3306−−mysql−user=mysql_user --mysql-password=mysqlpassword−−mysql−db=table_name --mysql-table-engine=innodb --oltp-table-size=[table_size/10] --oltp-tables-count=$oltp_tables_count -db-driver=mysql prepare

注意事项:
1.如果测试POLARDB不能使用外网连接串(时延高难以达到最佳性能)使用非VPC的内网连接串要达到最佳的性能需要使用3~4台ECS同时进行压测才能发挥Polardb最佳性能,使用VPC网络单台ECS压测就能达到POLARDB最佳的性能(建议使用VPC连接串)

2.POLARDB的特点是读写分离,sysbench测试时需要单独测试读和写,避免使用读写混合sysbench命令测试,这样能最大的发挥POLARDB的性能优势,详细测试命令如下:

压测写性能

使用sysbench准备数据,单表1000万数据,总共100个表,每个表的空间大约2G。
sysbenchpath/sysbench−−test=sysbenchpath/tests/db/oltp.lua --mysql-host=ip−−oltp−tables−count=oltp_tables_count --mysql-user=mysqluser−−mysql−password=mysql_password --mysql-port=3306 --db-driver=mysql --oltp-table-size=[table_size/10] --mysql-db=tablename−−max−requests=[tablesize/10]−−max−time=max_time --oltp_simple_ranges=0 --oltp-distinct-ranges=0 --oltp-sum-ranges=0 --oltporder-ranges=0 --oltp-point-selects=0 --num-threads=$threads --randtype=uniform run

压测读性能

压测选用5个表,每个表1000万数据,总共1亿条数据进行压测。分表采用1,2,4,8,16,32个并发测试写入性能。
sysbenchpath/sysbench−−test=sysbenchpath/tests/db/oltp.lua --mysql-host=ip−−oltp−tables−count=oltp_tables_count --mysql-user=mysqluser−−mysql−password=mysql_password --mysql-port=3306 --db-driver=mysql --oltp-table-size=[table_size/10] --mysql-db=tablename−−max−requests=[tablesize/10]−−oltpsimpleranges=0−−oltp−distinct−ranges=0−−oltp−sum−ranges=0−−oltp−order−ranges=0−−max−time=max_time --oltp-read-only=on --num-threads=$threads run

注:

  $sysbench_path:sysbench源码位置
$ip数据库的IP地址者公网连接串
$mysql_user 数据库用户名
$mysql_password 数据库密码
$table_name 数据库的名字
$oltp_tables_count 数据库表的数量
$table_size 数据库表的大小

压测结果

读取性能压测结果

在32个并发的时候,取得了最好的读区性能,读取QPS为46813.94,平均SQL响应时间2.05毫秒。

写性能压测结果
32个并发的时候,取得了最好的写入性能,写QPS为156273.72,平均事物响应时间5.09毫秒。

看文福利!每天可抽奖,代金券,天猫精灵等奖品等你拿!点击进入抽奖页面

本文为云栖社区原创内容,未经允许不得转载,如需转载请发送邮件至yqeditor@list.alibaba-inc.com;如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件至:yqgroup@service.aliyun.com 进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容。

阿里云原生数据库POLARDB压力测试报告相关推荐

  1. 直播丨云原生数据库PolarDB年度发布

    活动详情 作为第一个进入Gartner全球数据库领导者象限的中国数据库,阿里云数据库在数据管理及数据分析领域都拥有深厚的技术积累.云原生数据库PolarDB既解决了传统数据库容量有限.扩缩容时间长等问 ...

  2. 阿里云吕漫漪:深度解析国内首个云原生数据库POLARDB的“王者荣耀”

    关注,下载更多学习资源 数据技术嘉年华大会上,吕漫漪老师分享过后,企业网(d1net)采访了嘉年华嘉宾吕漫漪老师,这里我们整理分享出来. 大会PPT下载:关注"数据和云"回复&qu ...

  3. 阿里云自主研发云原生数据库POLARDB的开拓之路

    <创新.进化.竞合.开放--阿里云自主研发云原生数据库POLARDB的开拓之路> 阿里云ApsaraDB数据库 高级产品专家 贺军 前言 数据库作为信息时代平台科技(CPU/芯片.PC/手 ...

  4. 云原生数据库POLARDB专场“硬核”解析

    POLARDB是阿里巴巴自主研发的云原生关系型数据库,目前兼容三种数据库引擎:MySQL.PostgreSQL.Oracle.POLARDB的计算能力最高可扩展至1000核以上,存储容量可达100TB ...

  5. 《斗罗大陆》引入阿里云云原生数据库 PolarDB 游戏体验更流畅

    简介:文章来源:游戏开发世界 4 月 30 日,记者采访获悉,新浪游戏重磅作品<斗罗大陆 2 绝世唐门>全面引入阿里云云原生数据库 PolarDB,助力游戏运维效率提升 6 倍,海量数据承 ...

  6. 比MySQL快6倍 深度解析国内首个云原生数据库POLARDB的“王者荣耀”

    随着移动互联网.电子商务的高速发展,被使用最多的企业级开源数据系统MySQL面临着巨大挑战--为迎接"双11"的高并发要提前做好分库分表;用户不断激增要将读写分离才能应对每天上亿次 ...

  7. 深度解析国内首个云原生数据库POLARDB的“王者荣耀”

    随着移动互联网.电子商务的高速发展,被使用最多的企业级开源数据系统MySQL面临着巨大挑战--为迎接"双11"的高并发要提前做好分库分表;用户不断激增要将读写分离才能应对每天上亿次 ...

  8. 阿里云服务器的WebSocket压力测试报告

    阿里云服务器的WebSocket压力测试报告 模拟并发量:50000 基于服务器的压力测试: 测试结果: 在CPU爆掉之前,连接成功数一直在增加,连接失败数是0次 CPU爆掉之后,连接成功数不再增加, ...

  9. 阿里云原生数据库:POLARDB

    目录 POLARDB 产品架构简介 POLARDB 架构 POLARDB 的存储引擎性能优化 POLARDB 的计算引擎性能优化 如何降低成本 POLARDB 产品架构简介 POLARDB 是阿里云数 ...

最新文章

  1. 黑马程序员_Java面向对象_包
  2. Docker操作系统理解
  3. Go的channel与map是否并发安全以及原因
  4. 用为知发布博客到博客园、使用Wiz编写和发布博客园(cnblogs)博客
  5. 128位加密SSL证书
  6. 普通人能用华为P30拍出银河么?这是我们在北京实拍的结果
  7. 3. Longest Substring Without Repeating Characters
  8. 《系统集成项目管理》第一章 信息化知识
  9. WEB标准的学习和理解(一)何为WEB标准
  10. Python使用string.Formatter()制作打印模板
  11. 深度学习/自动驾驶数据集大集合(目标检测/图像分割/语义分割/图像分类/)
  12. Davinci的异构多核间通信基础组件SysLink 2.0
  13. matplotlib设置坐标轴
  14. unity 设置图片九宫格_Unity UGUI篇 Image图片
  15. AI识别抑郁症正确率高达八成,但AI+精神健康还有很长的路要走
  16. 淋巴细胞转化中PHP的作用,淋巴细胞转化试验范围|意义
  17. 职称申报神器-职称小百科告诉你专业对应的评委会
  18. ETL工程师_个人职责
  19. 小度机器人小胖机器人_小度机器人怎么升级?智能机器人百小度快速升级全攻略[多图]...
  20. 中文自然语言处理--基于 textCNN 的电影推荐系统

热门文章

  1. Linux: terminal 终端生存指南
  2. visibility: hidden与display:none的区别
  3. PHP API 框架开发的学习
  4. JavaScript判断浏览器 Browser detect
  5. SQL查询语句 select
  6. 如何在html文件中包含其他html文件
  7. ORB-SLAM2介绍(1)
  8. c++string类的常用方法详解
  9. 使用find命令查找文件
  10. 设计模式——单例模式详解