mysql mysqlslap 压力测试

mysqlslap

简介

mysql 压力测试工具

选项

选项 简写 说明
--auto-generate-sql -a 自动生成MySQL测试语句
--auto-generate-sql-add-autoincrement   添加AUTO_INCREMENT字段
--auto-generate-sql-execute-number=#   查询的个数
--auto-generate-sql-guid-primary   添加GUID字段
--auto-generate-sql-load-type=name   mixed:混合、update:更新、write:写入、key:读主键、read:查询
--auto-generate-sql-secondary-indexes=#   设置索引字段个数
--auto-generate-sql-unique-query-number=#   生成N条不同的query sql语句
--auto-generate-sql-unique-write-number=#   生成N条不同的write sql语句
--auto-generate-sql-write-number=#   每个线程write sql语句数量
--commit=#   设置每多少条sql语句提交一次
--compress -C 启用压缩协议
--concurrency=# -c 客户端数量(并发量)
--create=name   测试的SQL语句或文件
--create-schema=name   测试的数据名
--csv=name   生产CSV格式数据文件
--debug -# 写调试日志(windows不可用) 如:mysqlslap -a -#"d:t:o,c:/debug.txt"
--debug-check   测试后打印调试信息(windows不可用) 
--debug-info -T 打印内存和CPU的相关信息
--default-auth=plugin   验证插件
--delimiter=str -F 语句分隔符默认是 ;
--detach=#   执行N条语句后断开重连
--enable-cleartext-plugin   启用明文身份验证插件
--engine=engine_name -e 测试引擎 如:mysqlslap -e"myisam"或-e"myisam,innodb"
--help   帮助信息
--host=host_name -h 数据库host
--iterations=# -i 迭代运行次数
--login-path=name   登陆配置文件  详见
--no-drop   测试后不删除schema
--number-char-cols=# -x 设置VARCHAR类型字段数量
--number-int-cols=# -y 设置INT类型字段数量
--number-of-queries=#   每个客户端运行sql语句数量 受
--only-print   仅显示将被运行的SQL语句--delimiter选项影响
--password=password -p 数据库密码
--pipe   启用管道
--plugin-dir=path   插件目录
--port=port_num -P 数据库端口
--post-query=value   测试后执行的SQL语句
--post-system=str   测试后执行的系统语句
--pre-query=value   测试前执行的SQL语句
--pre-system=str   测试前执行的系统语句
--protocol=type   链接协议 tcp, socket, pipe
--query=value -q 测试的SQL语句 如:mysqlslap -q"SELECT * FROM t1"
--secure-auth   不要发送密码到服务器
--silent -s 不显示测试(静音测试)
--socket=path -S 连接服务器的socket
--ssl-ca=file_name    
--ssl-capath=dir_name    
--ssl-cert=file_name    
--ssl-cipher=cipher_list    
--ssl-crl=file_name    
--ssl-crlpath=dir_name    
--ssl-key=file_name    
--ssl-verify-server-cert    
--user=user_name -u 数据库用户名
--verbose -v 输出更多的信息
--version -V 版本信息

例子

  1. 远程测试如:mysqlslap -a -h"192.168.1.139" -P3306 -p
  2. 指定sql语句         如:mysqlslap --create-schema=test -q"select * from user"
  3. 自动测试             :mysqlslap -a
  4. 显示测试sql语句   :mysqlslap -a --only-print

报表

我们测试本地数据库引擎性能

mysqlslap -a -e"myisam,innodb" --csv="c:/a.csv"

c:/a.csv文件


我们转换成图表形式

可以看出 myisam,innodb 混合测试时myisam性能更好些 读写时间更少


常用选项

Windows默认配置文件读取顺序:
C:\WINDOWS\my.ini
C:\WINDOWS\my.cnf
C:\my.ini
C:\my.cnf
F:\mysql\5.6.16\my.ini 
F:\mysql\5.6.16\my.cnf




-h     数据库host
-u     数据库用户名
-p     数据库密码
-P     数据库端口


--create-schema=name    测试的数据名
--create=name           测试的SQL语句或文件
--no-drop            测试后不删除schema
--only-print     仅显示将被运行的SQL语句


-c                      客户端数量(并发量)      如:mysqlslap -c"10"或-c"10,100,1000"
-e                      测试引擎                如:mysqlslap -e"myisam"或-e"myisam,innodb"
--number-of-queries=# SQL语句执行总次数       如:mysqlslap -a --number-of-queries="10"
-q                      测试的SQL语句           如:mysqlslap -q"SELECT * FROM t1"
-i                      迭代运行次数            如:mysqlslap -a -i"3"
-T                      显示内存和CPU信息并退出 如:mysqlslap -a -T
-F                      SQL语句分隔符
-s                      不输出无回显运行


--csv[=name]            生产CSV格式数据文件
--commit=#              设置每多少条sql语句提交一次
--detach=#              设置每多少条sql语句重连服务器一次




-a,--auto-generate-sql                          自动生成MySQL测试语句
   --auto-generate-sql-add-autoincrement        添加AUTO_INCREMENT字段
   --auto-generate-sql-execute-number=#         查询的个数
   --auto-generate-sql-guid-primary             添加GUID字段
   --auto-generate-sql-load-type=name           mixed:混合、update:更新、write:写入、key:读主键、read:查询
   --auto-generate-sql-secondary-indexes=#      设置索引字段个数
   --auto-generate-sql-unique-query-number=#    生成N条不同的query sql语句
   --auto-generate-sql-unique-write-number=#    生成N条不同的write sql语句
   --auto-generate-sql-write-number=#           每个线程write sql语句数量
   -x, --number-char-cols=name                  设置VARCHAR类型字段数量 默认1
   -y, --number-int-cols=name                   设置INT    类型字段数量默认1

mysql mysqlslap 压力测试,古老的榕树,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。