首页 >数据库 >mysql教程 >mysqlmysqlslap压力测试_MySQL

mysqlmysqlslap压力测试_MySQL

WBOY
WBOY原创
2016-06-01 13:18:38832浏览
bitsCN.com

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:mysqlmysqlslap压力测试_MySQLdebug.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 版本信息

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

报表
我们测试本地数据库引擎性能
mysqlslap -a -e"myisam,innodb" --csv="c:mysqlmysqlslap压力测试_MySQLa.csv"

c:mysqlmysqlslap压力测试_MySQLa.csv文件 mysqlmysqlslap压力测试_MySQL

我们转换成图表形式 mysqlmysqlslap压力测试_MySQL
可以看出 myisam,innodb 混合测试时myisam性能更好些 读写时间更少

常用选项Windows默认配置文件读取顺序:
C:mysqlmysqlslap压力测试_MySQLWINDOWSmysqlmysqlslap压力测试_MySQLmy.ini
C:mysqlmysqlslap压力测试_MySQLWINDOWSmysqlmysqlslap压力测试_MySQLmy.cnf
C:mysqlmysqlslap压力测试_MySQLmy.ini
C:mysqlmysqlslap压力测试_MySQLmy.cnf
F:mysqlmysqlslap压力测试_MySQLmysqlmysqlmysqlslap压力测试_MySQL5.6.16mysqlmysqlslap压力测试_MySQLmy.ini
F:mysqlmysqlslap压力测试_MySQLmysqlmysqlmysqlslap压力测试_MySQL5.6.16mysqlmysqlslap压力测试_MySQLmy.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
bitsCN.com

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn