MySQL压测工具mysqlslap的介绍与使用
一、Mysqlslap介绍
mysqlslap是MySQL5.1之后自带的benchmark基准测试工具,类似ApacheBench负载产生工具,生成schema,装载数据,执行benckmark和查询数据,语法简单,灵活,容易使用。该工具可以模拟多个客户端同时并发的向服务器发出查询更新,给出了性能测试数据而且提供了多种引擎的性能比较。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=namemixed:混合、update:更新、write:写入、key:读主键、read:查询 --auto-generate-sql-secondary-indexes=#设置索引字段个数 --auto-generate-sql-unique-query-number=#生成N条不同的querysql语句 --auto-generate-sql-unique-write-number=#生成N条不同的writesql语句 --auto-generate-sql-write-number=#每个线程writesql语句数量 --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--query="SELECT*FROMt1" --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.分别测试100、200、400个并发执行10w条SQL。
mysqlslap-uroot-proot-h192.168.10.43-P3306--create-schema=chenmh--delimiter=";"--query="callpro_auto_select_pri"--concurrency=100,200,400--number-of-queries=100000
注意:报告输出的时间主要体现在执行完–number-of-queries指定的查询所花的时间,这里分别是100个并发、200个并发、400个并发执行10w条call所花的时间。默认不指定–iterations代表重复执行一次操作,如果重复执行N此输出的时间也是反应的是单次循环所花的时间。
2.生成csv
mysqlslap-a-e"myisam,innodb"--csv="c:/a.csv"
四、总结
mysqlslap主要还是针对数据库的性能测试,并且自动测试功能有限,而且生产报表也不够详细,所以建议还是使用sysbench来做基准测试。以上就是关于mysqlslap的全部介绍,希望对大家的学习或者工作带来一定的帮助,如果有疑问大家可以留言交流。