iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >使用sysbench对MySQL进行测试
  • 265
分享到

使用sysbench对MySQL进行测试

2024-04-02 19:04:59 265人浏览 独家记忆
摘要

因sysbench版本更新问题,某些命令选项发生改变,查询help进行酌情更改。 https://yq.aliyun.com/articles/66651?spm=5176.100239.bloGCont

因sysbench版本更新问题,某些命令选项发生改变,查询help进行酌情更改。

https://yq.aliyun.com/articles/66651?spm=5176.100239.bloGCont66870.15.0ouYNm

Http://iMysql.cn/2014/10/17/sysbench-full-user-manual.shtml

摘要: 为什么要测试,测什么东西? 测试的种类非常多,测试的目的也非常多,我这里主要的目的就两个 测试mysql的极限io 对比不同版本Mysql,不同参数, 不同硬件,不同系统对MySQL的性能影响 为什么选择sysbench 因为MySQL官方的测试就是用sysbench哦 尽量选择最新版本

为什么要测试,测什么东西?

测试的种类非常多,测试的目的也非常多,我这里主要的目的就两个

  1. 测试MySQL的极限IO

  2. 对比不同版本MySQL,不同参数, 不同硬件,不同系统对MySQL的性能影响

为什么选择sysbench

  1. 因为MySQL官方的测试就是用sysbench哦
  2. 尽量选择最新版本的sysbench哦,大于0.4版本的sysbench有实时显示功能

如何下载sysbench

http://GitHub.com/akopytov/sysbench

文档在哪里

http://github.com/akopytov/sysbench

如何安装

* 基本步骤 cd sysbench-1.0;
./autogen.sh;
./configure --with-mysql-includes=/usr/local/mysql/include --with-mysql-libs=/usr/local/mysql/lib/;
make;
make install; 
* 过程中可能会遇到的故障 
sysbench: error while loading shared libraries: libmysqlclient.so.20: cannot open shared object file: No such file or directory 
* 解决方案 export LD_LIBRARY_PATH=/usr/local/mysql/lib/; 
* 测试是否安装成功 shell> sysbench --version sysbench 1.0 

介绍sysbench的核心用法

  1. 它可以用来测试很多东西,测试io,cpu,mem,mysql,oracle,pg等等。
  2. 这里主要介绍我关心的两个,IO & MySQL
  3. 以下前半部分是0.4版本的用法,0.4以上的版本用法不一样,会注明。

一、通用语法

sysbench [common-options] --test=name [test-options] command 
  • command
* prepare 准备阶段,也就是装载数据。
 filo test 中: 就是创建指定大小的文件
 oltp test 中: 就是创建指定大小的表 
* run 实际测试阶段 
* cleanup 收尾阶段,清除之前测试的数据。 
  • common-options

只介绍常用的选项

选项 描述 默认值
--num-threads 多少个线程 1
--max-requests 多少个请求,0意味着无限制 1000
--max-time 测试多长时间,0意味着无限制 0
--test 测试什么模块 必须要求
--report-interval 阶段性的汇报测试统计信息,0.4以上版本新增
  • --test=fileio 模块的选项

提前注明:--file-test-mode

* seqwr
sequential write 
* seqrewr
sequential rewrite
* seqrd
sequential read 
* rndrd random read 
* rndwr random write 
* rndrw
combined random read/write 
  • test option for fileio
选项 描述 默认值
--file-num 创建文件的数量 128
--file-block-size IO操作的大小 16k
--file-total-size 所有文件的总大小 2G
--file-test-mode seqwr,seqrewr, seqrd, rndrd, rndwr, rndwr(上面已经介绍) 必须
--file-io-mode i/O 模式,sync, async, fastmmap, slowmmap sync
--file-extra-flags 以额外的标记(O_SYNC,O_DSYNC,O_DIRECT)打开 -
--file-fsync-freq 多少请求后使用fsync 100
--file-fsync-all 每次写IO都必须fsync no
--file-fsync-mode 用什么样的模式来同步文件fsync, fdatasync (see above) fsync
--file-rw-ratio 随机读写请求的比例 1.5

举例:

$ sysbench --num-threads=16 --test=fileio --file-total-size=3G --file-test-mode=rndrw prepare
$ sysbench --num-threads=16 --test=fileio --file-total-size=3G --file-test-mode=rndrw run 
$ sysbench --num-threads=16 --test=fileio --file-total-size=3G --file-test-mode=rndrw cleanup 

OLTP-MySQL

此模式用于测试真实数据库性能。在prepare阶段创建表,sbtest默认

CREATE TABLE `sbtest` ( `id` int(10) unsigned NOT NULL auto_increment, `k` int(10) unsigned NOT NULL default '0', `c` char(120) NOT NULL default '', `pad` char(60) NOT NULL default '',
PRIMARY KEY (`id`), KEY `k` (`k`)); 

在run阶段

  • simple模式
SELECT c FROM sbtest WHERE id=N 
  • Point queries
SELECT c FROM sbtest WHERE id=N 
  • Range queries:
SELECT c FROM sbtest WHERE id BETWEEN N AND M 
  • Range SUM() queries
SELECT SUM(K) FROM sbtest WHERE id BETWEEN N and M 
  • Range ORDER BY queries
SELECT c FROM sbtest WHERE id between N and M ORDER BY c 
  • Range DISTINCT queries
SELECT DISTINCT c FROM sbtest WHERE id BETWEEN N and M ORDER BY c 
  • UPDATEs on index column
UPDATE sbtest SET k=k+1 WHERE id=N 
  • UPDATEs on non-index column:
UPDATE sbtest SET c=N WHERE id=M 
  • DELETE queries
DELETE FROM sbtest WHERE id=N 
  • INSERT queries
INSERT INTO sbtest VALUES (...) 
  • oltp test 模式通用参数
选项 描述 默认值
--oltp-table-name 表的名字 sbtest
--oltp-table-size 表的行数 10000
--oltp-tables-count 表的个数 1
--oltp-dist-type 热点数据分布{unifORM(均匀分布),Gaussian(高斯分布),special(空间分布)}。默认是special special
--oltp-dist-pct special:热点数据产生的比例 1
--oltp-dist-res special:热点数据的访问频率 75
--oltp-test-mode simple,complex(以上介绍) complex
--oltp-read-only 只有select 请求 off
--oltp-skip-trx 不用事务 off
--oltp-point-selects 一个事务中简单select查询数量 10
--oltp-simple-ranges 一个事务中简单range查询的数量 1
--oltp-sum-ranges sum range的数量 1
--oltp-order=ranges order range的数量 1
  • mysql test 参数
 --mysql-host=[LIST,...]      MySQL Server host [localhost]  
--mysql-port=[LIST,...]      MySQL server port [3306]  
--mysql-Socket=[LIST,...]    MySQL socket  
--mysql-user=STRING          MySQL user [sbtest]  
--mysql-passWord=STRING      MySQL password []  
--mysql-db=STRING            MySQL database name [sbtest]  
--mysql-table-engine=STRING  storage engine to use for the test table {myisam,innodb,bdb,heap,ndbcluster,federated} [innodb]  
--mysql-engine-trx=STRING    whether storage engine used is transactional or not {yes,no,auto} [auto]  
--mysql-ssl=[on|off]         use SSL connections, if available in the client library [off]  
--mysql-ssl-cipher=STRING    use specific cipher for SSL connections []  
--mysql-compression=[on|off] use compression, if available in the client library [off]  
--myisam-max-rows=N          max-rows parameter for MyISAM tables [1000000]  
--mysql-debug=[on|off]       dump all client library calls [off]  
--mysql-ignore-errors=[LIST,...]list of errors to ignore, or "all" [1213,1020,1205]  
--mysql-dry-run=[on|off]     Dry run, pretent that all MySQL client api calls are successful without executing them [off] 

以上0.4版本的语法介绍完毕。

接下来是大于0.4版本的新语法,尤其是--test=oltp模块

用--test=xx.lua (完整路径来传递)来代替
[szq@upright91 local]$ locate select.lua 
/home/szq/sysbench-1.0.3/src/lua/oltp_point_select.lua
/home/szq/sysbench-1.0.3/tests/include/oltp_legacy/select.lua
/usr/local/share/sysbench/oltp_point_select.lua
/usr/local/share/sysbench/tests/include/oltp_legacy/select.lua
[szq@upright91 local]$ ll /home/szq/sysbench-1.0.3/tests/include/oltp_legacy
总用量 52
-rw-r--r-- 1 szq szq 1195 2月  26 05:12 bulk_insert.lua
-rw-r--r-- 1 szq szq 4696 2月  26 05:12 common.lua
-rw-r--r-- 1 szq szq  366 2月  26 05:12 delete.lua
-rw-r--r-- 1 szq szq 1171 2月  26 05:12 insert.lua
-rw-r--r-- 1 szq szq 3004 2月  26 05:12 oltp.lua
-rw-r--r-- 1 szq szq  368 2月  26 05:12 oltp_simple.lua
-rw-r--r-- 1 szq szq  527 2月  26 05:12 parallel_prepare.lua
-rw-r--r-- 1 szq szq  369 2月  26 05:12 select.lua
-rw-r--r-- 1 szq szq 1448 2月  26 05:12 select_random_points.lua
-rw-r--r-- 1 szq szq 1556 2月  26 05:12 select_random_ranges.lua
-rw-r--r-- 1 szq szq  369 2月  26 05:12 update_index.lua
-rw-r--r-- 1 szq szq  578 2月  26 05:12 update_non_index.lua

FileIO实战

磁盘:S3610 * 6 raid10, 内存128G
测试出相关场景下的极限IOPS

  • 随机读写(3:2 oltp场景)
* sysbench --num-threads=16 --report-interval=3 --max-requests=0 --max-time=300 --test=fileio --file-num=200 --file-total-size=200G \
--file-test-mode=rndrw --file-block-size=16384 --file-extra-flags=direct run 

  • 随机读写(5:1 oltp场景)
* sysbench --num-threads=16 --report-interval=3 --max-requests=0 --max-time=300 --test=fileio --file-num=200 --file-total-size=200G \
--file-test-mode=rndrw --file-block-size=16384 --file-extra-flags=direct --file-rw-ratio=5 run 

使用sysbench对MySQL进行测试

  • 随机写
* sysbench --num-threads=16 --report-interval=3 --max-requests=0 --max-time=300 --test=fileio --file-num=200 --file-total-size=200G \
--file-test-mode=rndwr --file-block-size=16384 --file-extra-flags=direct run 

使用sysbench对MySQL进行测试

  • 随机读
* sysbench --num-threads=16 --report-interval=3 --max-requests=0 --max-time=300 --test=fileio --file-num=200 --file-total-size=200G \
--file-test-mode=rndrd --file-block-size=16384 --file-extra-flags=direct run 

使用sysbench对MySQL进行测试

MySQL5.6 vs MySQL5.7 测试

磁盘:S3610 * 6 raid10, 内存128G

  • Point select
* 产生数据 sysbench --num-threads=128 --report-interval=3 --max-requests=0 --max-time=300 --test=/root/sysbench-1.0/sysbench/tests/db/select.lua \
--mysql-table-engine=innodb --oltp-table-size=50000000 --mysql-user=sysbench --mysql-password=sysbench --oltp-tables-count=2 --mysql-host=xx --mysql-port=3306 prepare 
* 执行 sysbench --num-threads=128 --report-interval=3 --max-requests=0 --max-time=300 --test=/root/sysbench-1.0/sysbench/tests/db/select.lua \
--mysql-table-engine=innodb --oltp-table-size=50000000 --mysql-user=sysbench --mysql-password=sysbench --oltp-tables-count=2 --mysql-host=xx --mysql-port=3306 run 

使用sysbench对MySQL进行测试

  • Point oltp
* 产生数据 sysbench --num-threads=128 --report-interval=3 --max-requests=0 --max-time=300 --test=/root/sysbench-1.0/sysbench/tests/db/oltp.lua \
--mysql-table-engine=innodb --oltp-table-size=50000000 --mysql-user=sysbench --mysql-password=sysbench --oltp-tables-count=2 --mysql-host=xx --mysql-port=3306 prepare 
* 执行 sysbench --num-threads=128 --report-interval=3 --max-requests=0 --max-time=300 --test=/root/sysbench-1.0/sysbench/tests/db/oltp.lua \
--mysql-table-engine=innodb --oltp-table-size=50000000 --mysql-user=sysbench --mysql-password=sysbench --oltp-tables-count=2 --mysql-host=xx --mysql-port=3306 run 

使用sysbench对MySQL进行测试

结论

  1. 在性能方面,虽然官方号称5.7性能比5.6快3倍,但是在实际测试中5.7比5.6却稍微差一点点
  2. 是否会选择5.7生产环境?当然,因为5.7的新特性太诱人了

参考:

https://www.percona.com/blog/2016/04/07/mysql-5-7-sysbench-oltp-read-results-really-faster/
http://dimitrik.free.fr/blog/arcHives/2013/09/mysql-performance-reaching-500k-qps-with-mysql-57.html
https://github.com/akopytov/sysbench
http://www.mysql.com/why-mysql/benchmarks/

您可能感兴趣的文档:

--结束END--

本文标题: 使用sysbench对MySQL进行测试

本文链接: https://www.lsjlt.com/news/46074.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何进行sysbench测试
    如何进行sysbench测试,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。sysbench支持以下几种测试模式:1、CPU运算...
    99+
    2024-04-02
  • 使用mysqlslap与sysbench怎么对MySQL进行压测
    这篇文章将为大家详细讲解有关使用mysqlslap与sysbench怎么对MySQL进行压测,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。mysqlslap...
    99+
    2024-04-02
  • 如何进行sysbench压力测试
    如何进行sysbench压力测试,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。 对于很多线上业务而言,如果有新服务器,新的...
    99+
    2024-04-02
  • Centos8下怎么使用Sysbench进行性能测试
    本篇内容介绍了“Centos8下怎么使用Sysbench进行性能测试”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!SysBench 是一个基...
    99+
    2023-06-27
  • Mysql压力测试(sysbench)
    目录 配置项目环境: 参考:采用sysbench压测mysql详解_dream21st的博客-CSDN博客 实验步骤: 1、安装sysbench工具 2、在master上创建用户和库,配置用户的权限可以使他可以访问库(Mysql的主从复制...
    99+
    2023-09-05
    mysql 压力测试 数据库
  • 如何使用sysbench测试Mysql性能
    这篇文章主要介绍了如何使用sysbench测试Mysql性能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 s...
    99+
    2024-04-02
  • [MySQL]-压力测试之Sysbench
    [MySQL]-压力测试之Sysbench 文章目录 [MySQL]-压力测试之Sysbench一、Sysbench概况1)介绍2)安装部署 二、实战1)构造测试数据2)开始运行压测结果...
    99+
    2023-09-04
    mysql 压力测试 数据库
  • MySQL如何使用sysbench做OLTP基准测试
    这篇文章给大家分享的是有关MySQL如何使用sysbench做OLTP基准测试的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 一、 安装① 下载源码...
    99+
    2024-04-02
  • 如何使用tpcc-mysql对mysql进行TPCC性能测试
    这篇文章主要介绍如何使用tpcc-mysql对mysql进行TPCC性能测试,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! tpcc-mysq是满足TPC...
    99+
    2024-04-02
  • 如何使用sysbench做oltp测试
    小编给大家分享一下如何使用sysbench做oltp测试,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!sysbench是一款开源...
    99+
    2024-04-02
  • Go单元测试对GORM进行Mock测试
    目录前言项目准备初始化测试工作对Create进行Mock测试Get 操作的Mock测试Update 操作的Mock测试总结前言 在 Go 单元测试这个系列的第二部分 数据库...
    99+
    2024-04-02
  • 如何使用单元测试框架对 Golang 函数进行测试?
    go 中使用单元测试框架进行单元测试:导入 testing 包。编写以 test 为前缀的单元测试函数。使用断言函数(如 assertequal())验证测试结果。运行单元测试(go t...
    99+
    2024-04-16
    golang 单元测试 标准库
  • 怎么使用HammerDB进行MySQL基准测试
    使用HammerDB进行MySQL基准测试的步骤如下: 首先,下载并安装HammerDB。你可以在HammerDB的官方网站(h...
    99+
    2023-10-24
    HammerDB MySQL
  • 使用 BenchmarkDotNet 对 C# 代码进行基准测试
    目录安装 BenchmarkDotNet 什么是基准测试 创建基准测试代码 运行 benchmark BenchmarkDotNet 是一个轻量级,开源的,强大的 .NET 工具包,...
    99+
    2024-04-02
  • MySQL中怎么使用hammerdb进行基准测试
    今天就跟大家聊聊有关MySQL中怎么使用hammerdb进行基准测试,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。root@master /usr/...
    99+
    2024-04-02
  • 使用 gorm 和 sqlmock 进行测试
    问题内容 我正在努力使用 sqlmock 和 gorm 为我的 go lambda 函数编写测试。 这是我要测试的功能: func docleanup(con *gorm.db) { ...
    99+
    2024-02-05
  • 仅使用公共 api 对 alexedwards/scs 进行简单测试
    php小编香蕉本文将介绍如何使用公共 API 对 Alex Edwards/SCS 进行简单测试。Alex Edwards/SCS 是一个用于会话管理的 PHP 库,可以轻松地在应用程...
    99+
    2024-02-09
  • 如何使用BenchmarkDotNet对C#代码进行基准测试
    这篇文章给大家分享的是有关如何使用BenchmarkDotNet对C#代码进行基准测试的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。BenchmarkDotNet 是一个轻量级,开源的,强大的 .NET 工具包,...
    99+
    2023-06-14
  • JMeter如何对MySQL数据库进行压力测试
    这篇文章将为大家详细讲解有关JMeter如何对MySQL数据库进行压力测试,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、安装并配置 JMeter下载官网下载,下载二进制的这个 zip配置环境变量然后解...
    99+
    2023-06-28
  • Go单元测试对数据库CRUD进行Mock测试
    目录前言go-sqlmock安装使用示例miniredis安装使用示例总结前言 最近在实践中也总结了一些如何用表格驱动的方式使用 gock Mock测试外部接口调用。以及怎么对GOR...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作