mysqlslap详解--MySQL⾃带的性能压⼒测试⼯具
mysqlslap 是 Mysql ⾃带的压⼒测试⼯具,可以模拟出⼤量客户端同时操作数据库的情况,通过结果信息来了解数据库的性能状况mysqlslap 的⼀个主要⼯作场景就是对数据库服务器做基准测试
例如我们拿到了⼀台服务器,准备做为数据库服务器,那么这台服务器的硬件资源能够⽀持多⼤的访问压⼒呢?优化了操作系统的内核参数后,是否提升了性能?调整了Mysql配置参数后,对性能有多少影响?……
通过⼀系列的调优⼯作,配合基准测试,就可以把这台服务器调整到最佳状态,也掌握了健康状态下的性能指标
以后在实际运⾏过程中,当监控的数据接近了基准指标时,说明数据库服务器快要满负荷了,需要分析是数据库结构设计、SQL语句这类⽤法问题,还是硬件资源的确不够了,然后进⾏相应的处理
数据库服务器也可能需要硬件升级,升级之后也需要进⾏基准测试,和之前的测试结果对⽐,确保升级后的性能是提升的,防⽌不恰当的升级或者错误的配置引起性能下降
了解了 mysqlslap 的⽤处,下⾯看⼀下如何使⽤ mysqlslap
mysqlslap ⽰例
01简单⽤法
对数据库做⼀个简单的⾃动测试
mysqlslap –user=root –password=111111 –auto-generate-sql
–auto-generate-sql 作⽤是⾃动⽣成测试SQL
结果中各项含义:
Average number of …
运⾏所有语句的平均秒数
Minimum number of …
运⾏所有语句的最⼩秒数
Maximum number of …
运⾏所有语句的最⼤秒数
Number of clients …
客户端数量
Average number of queries per client
每个客户端运⾏查询的平均数
02添加并发
mysqlslap –user=root –password=111111 –concurrency=100 –number-of-queries=1000 –auto-generate-sql
–concurrency=100 指定同时有100个客户端连接
–number-of-queries=1000 指定总的测试查询次数(并发客户端数 * 每个客户端的查询次数)
03⾃动⽣成复杂表
⾃动测试时,创建的表结构⾮常简单,只有两列,实际的产品环境肯定会更复杂,可以使⽤参数指定列的数量和类型,例如
mysqlslap –user=root –password=111111 –concurrency=50 –number-int-cols=5 –number-char-cols=20 –auto-generate-sql
–number-int-cols=5 指定⽣成5个 int 类型的列
–number-char-cols=20 指定⽣成20个 char 类型的列
04使⽤⾃⼰的测试库和测试语句
⾃动测试可以帮助我们了解硬件层⾯的状况,对于我们产品特定的情况,还是使⽤⾃⼰的库来测试⽐较好,可以复制⼀份产品库过来,然后对此库测试,例如
mysqlslap –user=root –password=111111 –concurrency=50 –create-schema=employees –query=”SELECT * FROM dept_emp;”
–create-schema ⽤来指定测试库名称
–query 是⾃定义的测试语句
实际使⽤时,⼀般是测试多个复杂的语句,可以定义⼀个脚本⽂件,例如
echo “SELECT * FROM employees;SELECT * FROM titles;SELECT * FROM dept_emp;SELECT * FROM dept_manager;SELECT * FROM departments;” > ~/select_query.sql
把多个查询语句写⼊了⼀个 sql ⽂件,然后使⽤此⽂件执⾏测试
mysqlslap –user=root –password=111111 –concurrency=20 –number-of-queries=1000 –create-schema=employees –
query=”select_query.sql” –delimiter=”;”
–query 中指定了sql⽂件
–delimiter 说明sql⽂件中语句间的分隔符是什么
PS:今天⼀同事问我有⽊有⽐较靠谱的压⼒测试⼯具可⽤。其实mysql⾃带就有⼀个叫mysqlslap的压⼒测试⼯具,还是模拟的不错的。下⾯举例说说。mysqlslap是从5.1.4版开始的⼀个MySQL官⽅提供的压⼒测试⼯具。通过模拟多个并发客户端访问MySQL来执⾏压⼒测试,同时详细的提供了“⾼负荷攻击MySQL”的数据性能报告。并且能很好的对⽐多个存储引擎在相同环境下的并发压⼒性能差别。通过
mysqlslap –help可以获得可⽤的选项,这⾥列⼀些主要的参数,更详细的说明参考。如果是系统⾃带或者使⽤rpm包安装的mysql,安装了MySQL-client端的包就有mysqlslap这个⼯具。
下图是运⾏mysqlslap -a -c 500 -i 10 -uroot -p123456测试时mysql的连接进程数:
使⽤语法如下:
# mysqlslap [options]
常⽤参数 [options] 详细说明:
--auto-generate-sql, -a ⾃动⽣成测试表和数据,表⽰⽤mysqlslap⼯具⾃⼰⽣成的SQL脚本来测试并发压⼒。
--auto-generate-sql-load-type=type 测试语句的类型。代表要测试的环境是读操作还是写操作还是两者混合的。取值包括:
read,key,write,update和mixed(默认)。
--auto-generate-sql-add-auto-increment 代表对⽣成的表⾃动添加auto_increment列,从5.1.18版本开始⽀持。
--number-char-cols=N, -x N ⾃动⽣成的测试表中包含多少个字符类型的列,默认1
--number-int-cols=N, -y N ⾃动⽣成的测试表中包含多少个数字类型的列,默认1
--number-of-queries=N 总的测试查询次数(并发客户数×每客户查询次数)
--query=name,-q 使⽤⾃定义脚本执⾏测试,例如可以调⽤⾃定义的⼀个存储过程或者sql语句来执⾏测试。
--create-schema 代表⾃定义的测试库名称,测试的schema,MySQL中schema也就是。
--commint=N 多少条DML后提交⼀次。
--compress, -C 如果服务器和客户端⽀持都压缩,则压缩信息传递。
--concurrency=N, -c N 表⽰并发量,也就是模拟多少个客户端同时执⾏select。可指定多个值,以逗号或者--delimiter参数指定的值做为分隔符。例如:--concurrency=100,200,500。
--engine=engine_name, -e engine_name 代表要测试的引擎,可以有多个,⽤分隔符隔开。例如:--engines=myisam,innodb。
mysql连接工具-
-iterations=N, -i N 测试执⾏的迭代次数,代表要在不同并发环境下,各⾃运⾏测试多少次。
--only-print 只打印测试语句⽽不实际执⾏。
--detach=N 执⾏N条语句后断开重连。
--debug-info, -T 打印内存和CPU的相关信息。
说明:
测试的过程需要⽣成测试表,插⼊测试数据,这个mysqlslap可以⾃动⽣成,默认⽣成⼀个mysqlslap的schema,如果已经存在则先删除。可以⽤--only-print来打印实际的测试过程,整个测试完成后不会在数据库中留下痕迹。
各种测试参数实例(-p后⾯跟的是mysql的root密码):
单线程测试。测试做了什么。
# mysqlslap -a -uroot -p123456
多线程测试。使⽤–concurrency来模拟并发连接。
# mysqlslap -a -c 100 -uroot -p123456
迭代测试。⽤于需要多次执⾏测试得到平均值。
# mysqlslap -a -i 10 -uroot -p123456
# mysqlslap ---auto-generate-sql-add-autoincrement -a -uroot -p123456
# mysqlslap -a --auto-generate-sql-load-type=read -uroot -p123456
# mysqlslap -a --auto-generate-secondary-indexes=3 -uroot -p123456
# mysqlslap -a --auto-generate-sql-write-number=1000 -uroot -p123456
# mysqlslap --create-schema world -q "select count(*) from City" -uroot -p123456
# mysqlslap -a -e innodb -uroot -p123456
# mysqlslap -a --number-of-queries=10 -uroot -p123456
测试同时不同的存储引擎的性能进⾏对⽐:
# mysqlslap -a --concurrency=50,100 --number-of-queries 1000 --iterations=5 --engine=myisam,innodb --debug-info -uroot -p123456
执⾏⼀次测试,分别50和100个并发,执⾏1000次总查询:
# mysqlslap -a --concurrency=50,100 --number-of-queries 1000 --debug-info -uroot -p123456
50和100个并发分别得到⼀次测试结果(Benchmark),并发数越多,执⾏完所有查询的时间越长。为了准确起见,可以多迭代测试⼏次:
# mysqlslap -a --concurrency=50,100 --number-of-queries 1000 --iterations=5 --debug-info -uroot -p123456

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。