用sysbench测试mysql

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用版 2核4GB 50GB
简介: 在github上有安装说明

安装

在github上有安装说明:https://github.com/akopytov/sysbench


curl -s https://packagecloud.io/install/repositories/akopytov/sysbench/script.deb.sh | sudo bash
 sudo apt -y install sysbench

准备数据

root@scutech:/mysql/data# mysqladmin create sbtest
root@scutech:/mysql/data# sysbench --test=/usr/share/sysbench/tests/include/oltp_legacy/oltp.lua --oltp-table-size=10000 --oltp-tables-count=10  --oltp-test-mode=complex --time=120 --report-interval=10 prepare  --mysql-user=root --mysql-password=dingjia
scutech@scutech:/mysql/data/sbtest$ ll
total 102572
drwxr-x---  2 mysql mysql     4096 Mar  4 21:03 ./
drwxr-xr-x 12 mysql mysql     4096 Mar  4 21:03 ../
-rw-r-----  1 mysql mysql       65 Mar  4 21:03 db.opt
-rw-r-----  1 mysql mysql     8632 Mar  4 21:03 sbtest1.frm
-rw-r-----  1 mysql mysql 10485760 Mar  4 21:03 sbtest1.ibd
-rw-r-----  1 mysql mysql     8632 Mar  4 21:03 sbtest10.frm
-rw-r-----  1 mysql mysql 10485760 Mar  4 21:04 sbtest10.ibd
-rw-r-----  1 mysql mysql     8632 Mar  4 21:03 sbtest2.frm
-rw-r-----  1 mysql mysql 10485760 Mar  4 21:04 sbtest2.ibd
-rw-r-----  1 mysql mysql     8632 Mar  4 21:03 sbtest3.frm
-rw-r-----  1 mysql mysql 10485760 Mar  4 21:04 sbtest3.ibd
-rw-r-----  1 mysql mysql     8632 Mar  4 21:03 sbtest4.frm
-rw-r-----  1 mysql mysql 10485760 Mar  4 21:04 sbtest4.ibd
-rw-r-----  1 mysql mysql     8632 Mar  4 21:03 sbtest5.frm
-rw-r-----  1 mysql mysql 10485760 Mar  4 21:04 sbtest5.ibd
-rw-r-----  1 mysql mysql     8632 Mar  4 21:03 sbtest6.frm
-rw-r-----  1 mysql mysql 10485760 Mar  4 21:04 sbtest6.ibd
-rw-r-----  1 mysql mysql     8632 Mar  4 21:03 sbtest7.frm
-rw-r-----  1 mysql mysql 10485760 Mar  4 21:04 sbtest7.ibd
-rw-r-----  1 mysql mysql     8632 Mar  4 21:03 sbtest8.frm
-rw-r-----  1 mysql mysql 10485760 Mar  4 21:04 sbtest8.ibd
-rw-r-----  1 mysql mysql     8632 Mar  4 21:03 sbtest9.frm
-rw-r-----  1 mysql mysql 10485760 Mar  4 21:04 sbtest9.ibd
scutech@scutech:/mysql/data/sbtest$ du -sh .
101M  .



从docker中运行

准备工作

在mysql的客户端中运行

CREATE SCHEMA sbtest;
CREATE USER sbtest@'%' IDENTIFIED BY 'password';
GRANT ALL PRIVILEGES ON sbtest.* to sbtest@'%';


造数据的工作


time docker run \
--rm=true \
--name=sb-prepare \
severalnines/sysbench \
sysbench \
--db-driver=mysql \
--oltp-table-size=10000000 \
--oltp-tables-count=24 \
--threads=1 \
--mysql-host=192.168.87.205 \
--mysql-port=3306 \
--mysql-user=sbtest \
--mysql-password=password \
/usr/share/sysbench/tests/include/oltp_legacy/parallel_prepare.lua \
run


清除把run 改成cleanup

运行结果

queries performed:
        read:                            0
        write:                           89760
        other:                           48
        total:                           89808
    transactions:                        1      (0.00 per sec.)
    queries:                             89808  (21.72 per sec.)
    ignored errors:                      0      (0.00 per sec.)
    reconnects:                          0      (0.00 per sec.)
General statistics:
    total time:                          4134.4101s
    total number of events:              1
Latency (ms):
         min:                              4134408.88
         avg:                              4134408.88
         max:                              4134408.88
         95th percentile:                   100000.00
         sum:                              4134408.88
Threads fairness:
    events (avg/stddev):           1.0000/0.00
    execution time (avg/stddev):   4134.4089/0.00
real  68m58.429s
user  0m0.732s
sys 0m0.287s


数据大小


[root@base-test-01 sbtest]# du -sh .

55G .


可以认为一个小时生成了50G的内容

查看帮助

--name=sb-run \
 severalnines/sysbench \
 sysbench /usr/share/sysbench/oltp_common.lua help


从docker中运行 the benchmark for MySQL:

$ docker run \
--name=sb-run \
severalnines/sysbench \
sysbench \
--db-driver=mysql \
--report-interval=2 \
--mysql-table-engine=innodb \
--oltp-table-size=100000 \
--oltp-tables-count=24 \
--threads=64 \
--time=99999 \
--mysql-host=10.0.0.51 \
--mysql-port=3306 \
--mysql-user=sbtest \
--mysql-password=password \
/usr/share/sysbench/tests/include/oltp_legacy/oltp.lua \
run



服务器测试

测试环境配置

服务器 DELL PowerEdge R820

CPU Intel® Xeon® CPU E5-4650 v2 @ 2.40GHz 4个10核

内存 256G DDR-3

存储 1111.25GB 71862.50GB SATA SSD

操作系统 Centos 7.7 64bit

内核 3.10.0-1062.el7.x86_64


造数据

用140个线程造2000个表的数据

scutech@infokist:/md10$ sysbench oltp_common --tables=2000 --table-size=1000000 --mysql-user=root --mysql-password=dingjia --mysql-host=192.168.87.178  prepare --threads=140


生成数据近500G


[oracle@localhost ~]$ sudo du -sh /u01/mysql/data/sbtest/
469G  /u01/mysql/data/sbtest/
[oracle@localhost ~]$

造数据时服务器的压力如下:

image.png

如果需要清除数据用下面的命令,清除10个表的数据:

sysbench oltp_common cleanup --mysql-user=root --mysql-password=dingjia --mysql-host=192.168.87.178 --tables=10


测试run

开始测试


sysbench oltp_read_write  --tables=1000 --table-size=1000000 --mysql-user=root --mysql-password=dingjia --mysql-host=192.168.87.178 --threads=80 --report-interval=10 --time=1000 run

运行时出错,提示:


FATAL: MySQL error: 1461 "Can't create more than max_prepared_stmt_count statements (current value: 16382)"

修改参数后解决

mysql> set persist max_prepared_stmt_count=100000;
Query OK, 0 rows affected (0.00 sec)
mysql>  show global status like 'com_stmt%';
+-------------------------+---------+
| Variable_name           | Value   |
+-------------------------+---------+
| Com_stmt_execute        | 1883907 |
| Com_stmt_close          | 720080  |
| Com_stmt_fetch          | 0       |
| Com_stmt_prepare        | 820240  |
| Com_stmt_reset          | 0       |
| Com_stmt_send_long_data | 0       |
| Com_stmt_reprepare      | 0       |
+-------------------------+---------+
7 rows in set (0.01 sec)


image.png

sysbench提示的性能如下


[ 520s ] thds: 80 tps: 1000.19 qps: 20014.08 (r/w/o: 14012.02/4001.68/2000.39) lat (ms,95%): 116.80 err/s: 0.00 reconn/s: 0.00
[ 530s ] thds: 80 tps: 1000.00 qps: 20001.64 (r/w/o: 14001.56/4000.09/1999.99) lat (ms,95%): 116.80 err/s: 0.00 reconn/s: 0.00
[ 540s ] thds: 80 tps: 1003.10 qps: 20054.76 (r/w/o: 14035.98/4012.59/2006.20) lat (ms,95%): 116.80 err/s: 0.00 reconn/s: 0.00
[ 550s ] thds: 80 tps: 1000.71 qps: 20015.13 (r/w/o: 14010.49/4003.23/2001.41) lat (ms,95%): 116.80 err/s: 0.00 reconn/s: 0.00
[ 1000s ] thds: 80 tps: 997.28 qps: 19940.16 (r/w/o: 13957.16/3988.53/1994.47) lat (ms,95%): 118.92 err/s: 0.00 reconn/s: 0.00
SQL statistics:
    queries performed:
        read:                            13978370
        write:                           3993820
        other:                           1996910
        total:                           19969100
    transactions:                        998455 (997.15 per sec.)
    queries:                             19969100 (19942.94 per sec.)
    ignored errors:                      0      (0.00 per sec.)
    reconnects:                          0      (0.00 per sec.)
General statistics:
    total time:                          1001.3063s
    total number of events:              998455
Latency (ms):
         min:                                    9.92
         avg:                                   80.12
         max:                                  902.25
         95th percentile:                      116.80
         sum:                             79998913.63
Threads fairness:
    events (avg/stddev):           12480.6875/823.73
    execution time (avg/stddev):   999.9864/0.05



每秒的tps是1000,每秒大约2万个sql语句

从enterprise monitor 中截取的数据如下:

image.png

在top观察的mysqld进程的res随着业务量上来后的运行不断的增加。


和同一机器Oracle的测试对比

oracle用swingbench的测试


项目 MySQL测试结果 Oracle测试结果

TPS 1000 10000

qps 20000 146463

Transactions 997 6151.5

感觉MySQL的innodb明显没有Oracle吞吐量大呀!

而且My取消binlog和把innodb_flush_log_at_trx_commit为1也没有看到性能有什么变化。


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
14天前
|
关系型数据库 MySQL OLTP
性能工具之 MySQL OLTP Sysbench BenchMark 测试示例
【8月更文挑战第6天】使用 pt-query-digest 工具分析 MySQL 慢日志性能工具之 MySQL OLTP Sysbench BenchMark 测试示例
57 0
性能工具之 MySQL OLTP Sysbench BenchMark 测试示例
|
1月前
|
数据库
基于PHP+MYSQL开发制作的趣味测试网站源码
基于PHP+MYSQL开发制作的趣味测试网站源码。可在后台提前设置好缘分, 自己手动在数据库里修改数据,数据库里有就会优先查询数据库的信息, 没设置的话第一次查询缘分都是非常好的 95-99,第二次查就比较差 , 所以如果要你女朋友查询你的名字觉得很好 那就得是她第一反应是查和你的缘分, 如果查的是别人,那不好意思,第二个可能是你。
40 3
|
13天前
|
SQL 缓存 关系型数据库
MySQL配置简单优化与读写测试
MySQL配置简单优化与读写测试
|
2月前
|
存储 关系型数据库 MySQL
Baidu Comate Web在线出题能力测试——MySQL出题能力
Baidu Comate Web在线出题能力测试——MySQL出题能力
26 0
|
1月前
|
JSON JavaScript 测试技术
Postman接口测试工具详解
Postman接口测试工具详解
66 1
|
23天前
|
存储
Postman 接口测试配置 Pre-request Script
Postman 接口测试配置 Pre-request Script
66 5
Postman 接口测试配置 Pre-request Script
|
12天前
|
SQL 安全 测试技术
[go 面试] 接口测试的方法与技巧
[go 面试] 接口测试的方法与技巧
|
1月前
|
XML JSON 测试技术
Postman接口测试工具详解
📚 Postman全攻略:API测试神器!📚 发送HTTP请求,管理集合,写测试脚本,集成CI/CD。从安装配置到环境变量、断言、数据驱动测试,一步步教你如何高效测试RESTful API。实战案例包含GET、POST、PUT、DELETE请求。用Newman在命令行跑集合,自动化测试不发愁!👉 [洛秋小站](https://www.luoqiu.site/) 学更多!🚀
61 1
|
21天前
|
JSON 前端开发 测试技术
Postman 接口测试工具详解
在执行这些测试案例时,请确保遵循实际的API规范,并根据API的特定要求调整步骤和参数。
|
1月前
|
数据采集 测试技术
常见测试测量接口的比较:PXI、PXIe、PCI、VXI、GPIB、USB
常见测试测量接口的比较:PXI、PXIe、PCI、VXI、GPIB、USB
49 2

热门文章

最新文章