mysqls压力测试怎么用_mysql 压力测试工具

mysqlslap是一个mysql官方提供的压力测试工具。以下是比较重要的参数:

–defaults-file,配置文件存放位置

–concurrency,并发数

–engines,引擎

–iterations,迭代的实验次数

–socket,socket文件位置

自动测试:

–auto-generate-sql,自动产生测试SQL

–auto-generate-sql-load-type,测试SQL的类型。类型有mixed,update,write,key,read。

–number-of-queries,执行的SQL总数量

–number-int-cols,表内int列的数量

–number-char-cols,表内char列的数量

例如:

shell>mysqlslap –defaults-file=/u01/mysql1/mysql/my.cnf –concurrency=50,100 –iterations=1 –number-int-cols=4 –auto-generate-sql –auto-generate-sql-load-type=write –engine=myisam –number-of-queries=200 -S/tmp/mysql1.sock

Benchmark

Running for engine myisam

Average number of seconds to run all queries: 0.016 seconds

Minimum number of seconds to run all queries: 0.016 seconds

Maximum number of seconds to run all queries: 0.016 seconds

Number of clients running queries: 50

Average number of queries per client: 4

Benchmark

Running for engine myisam

Average number of seconds to run all queries: 0.265 seconds

Minimum number of seconds to run all queries: 0.265 seconds

Maximum number of seconds to run all queries: 0.265 seconds

Number of clients running queries: 100

Average number of queries per client: 2

指定数据库的测试:

–create-schema,指定数据库名称

–query,指定SQL语句,可以定位到某个包含SQL的文件

例如:

shell>mysqlslap –defaults-file=/u01/mysql1/mysql/my.cnf –concurrency=25,50 –iterations=1 –create-schema=test –query=/u01/test.sql -S/tmp/mysql1.sock

Benchmark

Average number of seconds to run all queries: 0.018 seconds

Minimum number of seconds to run all queries: 0.018 seconds

Maximum number of seconds to run all queries: 0.018 seconds

Number of clients running queries: 25

Average number of queries per client: 1

Benchmark

Average number of seconds to run all queries: 0.011 seconds

Minimum number of seconds to run all queries: 0.011 seconds

Maximum number of seconds to run all queries: 0.011 seconds

Number of clients running queries: 50

Average number of queries per client: 1

另:

Mysqlslap是从5.1.4版开始的一个MySQL官方提供的压力测试工具。通过模拟多个并发客户端访问MySQL来执行压力测试,同时详细的提供了“高负荷攻击MySQL”的数据性能报告。并且能很好的对比多个存储引擎在相同环境下的并发压力性能差别。

它的使用语法如下:

shell>/usr/local/mysql/bin/mysqlslap [options]

常用参数【options】详细介绍:

--concurrency代表并发数量,多个可以用逗号隔开。例如:--concurrency=50,200,500

--engines代表要测试的引擎,可以有多个,用分隔符隔开。例如:--engines=myisam,innodb,memory

--iterations代表要在不同并发环境下,各自运行测试多少次。

--auto-generate-sql 代表用mysqlslap工具自己生成的SQL脚本来测试并发压力。

--auto-generate-sql-add-auto-increment 代表对生成的表自动添加auto_increment列,从5.1.18版本开始,

--auto-generate-sql-load-type 代表要测试的环境是读操作还是写操作还是两者混合的(read,write,update,mixed)

--number-of-queries 代表总共要运行多少条查询。

--debug-info 代表要额外输出CPU以及内存的相关信息。

--number-int-cols 代表示例表中的INTEGER类型的属性有几个。

--number-char-cols代表示例表中的vachar类型的属性有几个。

--create-schema 代表自定义的测试库名称。

--query 代表自定义的测试SQL脚本。

说明:

测试的过程需要生成测试表,插入测试数据,这个mysqlslap可以自动生成,默认生成一个mysqlslap的schema,如果已经存在则先删除。可以用-only-print来打印实际的测试过程,整个测试完成后不会在数据库中留下痕迹。

实验步骤:

练习一:

单线程测试。测试做了什么。

>./bin/mysqlslap -a -uroot -p111111

多线程测试。使用--concurrency来模拟并发连接。

> ./bin/mysqlslap -a -c 100 -uroot -p111111

迭代测试。用于需要多次执行测试得到平均值。

> ./bin/mysqlslap -a -i 10 -uroot -p111111

练习二:

> ./bin/mysqlslap -auto-generate-sql-add-autoincrement -a -uroot -p111111

> ./bin/mysqlslap -a -auto-generate-sql-load-type=read -uroot -p111111

> ./bin/mysqlslap -a -auto-generate-secondary-indexes=3 -uroot -p111111

> ./bin/mysqlslap -a -auto-generate-sql-write-number=1000 -uroot -p111111

> ./bin/mysqlslap --create-schema world -q "select count(*) from City" -uroot -p111111

> ./bin/mysqlslap -a -e innodb -uroot -p111111

> ./bin/mysqlslap -a --number-of-queries=10 -uroot -p111111

练习三:

执行一次测试,分别50和100个并发,执行1000次总查询:

> ./bin/mysqlslap -a --concurrency=50,100 --number-of-queries 1000 --debug-info -uroot -p111111

50和100个并发分别得到一次测试结果(Benchmark),并发数越多,执行完所有查询的时间越长。为了准确起见,可以多迭代测试几次:

> ./bin/mysqlslap -a --concurrency=50,100 --number-of-queries 1000 --iterations=5 --debug-info -uroot -p111111

测试同时不同的存储引擎的性能进行对比:

>./bin/mysqlslap -a --concurrency=50,100 --number-of-queries 1000 --iterations=5 --engine=myisam,innodb --debug-info -uroot -p111111

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值