Xtradb+Haproxy高可用数据库集群(三)sysbench性能测试篇

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: xtradb sysbench性能测试安装sysbench,最新版本是0.5yum install sysbench -y 初始化测试表sysbench --test=/usr/share/doc/sysbench/tests/db/oltp.

xtradb sysbench性能测试

安装sysbench,最新版本是0.5

yum install sysbench -y

 

初始化测试表

sysbench --test=/usr/share/doc/sysbench/tests/db/oltp.lua --oltp-table-size=1000000 --mysql-table-engine=innodb --mysql-user=sysbench  --mysql-password=sysbench --mysql-port=3306 --mysql-host=10.0.37.123 --mysql-db=test prepare

参数说明:

--oltp-table-size    指定表的大小,即表的行数

--mysql-table-engine:  指定存储引擎,如myisaminnodbheapndbclusterbdbmariafalconpbxt

--mysql-db       指定在哪个数据库创建测试表,默认为sbtest库,需要提前创建好

--test           指定Lua脚本,参数选项大部分同老版本的--test=oltp help

--db-driver      指定驱动,默认为Mysql

--myisam-max-rows:     指定Myisam表的MAX_ROWS选项

--oltp-secondary     测试表将使用二级索引KEY xid(ID) 替代 PRIMARY KEY (ID)innodb引擎内部为每个表创建唯一6字节的主键索引

--oltp-auto-inc    设置id列为auto-incremental,值为onoff,默认为on

 

select测试

sysbench --test=/usr/share/doc/sysbench/tests/db/select.lua   --oltp-table-size=1000000 --mysql-table-engine=innodb --mysql-user=sbtest  --mysql-password=sbpass --mysql-port=3306 --mysql-host=192.168.70.72 --mysql-db=sbtest  --max-requests=0 --max-time=120 --oltp-tables-count=1 --report-interval=10 --num-threads=8  run

参数说明:

  --max-time        来指定测试时长

--oltp-tables-count    指定测试表数量

--max-requests       指定最大请求数,默认100000是不限制

--num-threads        指定线程数

prepare         是一个准备过程,比如测oltp需要load数据到表里

run              是真正的测试过程

cleanup         是清除过程

update测试

sysbench --test=/usr/share/doc/sysbench/tests/db/update_index.lua  --oltp-table-size=1000000 --mysql-table-engine=innodb --mysql-user=sbtest  --mysql-password=sbpass --mysql-port=3306 --mysql-host=192.168.70.72 --mysql-db=sbtest  --max-requests=0 --max-time=120 --oltp-tables-count=1 --report-interval=10 --num_threads=8 run

 

insert测试

sysbench --test=/usr/share/doc/sysbench/tests/db/insert.lua  --oltp-table-size=1000000 --mysql-table-engine=innodb --mysql-user=sbtest  --mysql-password=sbpass --mysql-port=3306 --mysql-host=192.168.70.72 --mysql-db=sbtest  --max-requests=0 --max-time=120 --oltp-tables-count=1 --report-interval=10 --num_threads=8 run

 

测试结果

8线程 120s 插入120s 更新120s
一台 578859 76204 70780
二台 531659 90487 91068
三台 459249 88791 81759
一台不过
haproxy
718150 76268 69842


在写上,过haproxy时,一台与多台差距不大,多台对写性能影响不大。

在读上,按理来说,多台应该性能成倍上升,但从测试结果上看,没什么变化,不知道为什么,有人知道原因还请告知。



相关实践学习
通过性能测试PTS对云服务器ECS进行规格选择与性能压测
本文为您介绍如何利用性能测试PTS对云服务器ECS进行规格选择与性能压测。
相关文章
|
8月前
|
关系型数据库 MySQL C语言
mysql的压力测试软件sysbench
mysql的压力测试软件sysbench
50 1
|
SQL 存储 算法
【MySQL调优、分库分表、读写分离、高可用】
【MySQL调优、分库分表、读写分离、高可用】
247 0
|
关系型数据库 MySQL 测试技术
|
监控 安全 关系型数据库
|
监控 关系型数据库 MySQL
|
SQL 负载均衡 前端开发
基于Patroni的Citus高可用环境部署
Citus是一个非常实用的能够使PostgreSQL具有进行水平扩展能力的插件,或者说是一款以PostgreSQL插件形式部署的基于PostgreSQL的分布式HTAP数据库。本文简单说明Citus的高可用技术方案,并实际演示基于Patroni搭建Citus HA环境的步骤。
2718 0
|
存储 缓存 监控
MySQL - 高可用性:少宕机即高可用?
MySQL - 高可用性:少宕机即高可用?我们之前了解了复制、扩展性,接下来就让我们来了解可用性。归根到底,高可用性就意味着 "更少的宕机时间"。 老规矩,讨论一个名词,首先要给它下个定义,那么什么是可用性? 1 什么是可用性我们常见的可用性通常以百分比表示,这本身就有其隐藏的意味:高可用性不是绝对的。
1333 0