搜索
首页数据库mysql教程MySQL 压力测试工具 mysqlslap 使用总结

mysqlslap 可以用于模拟服务器的负载,并输出计时信息。其被包含在 MySQL 5.1 的发行包中。测试时,可以指定并发连接数,可以指定

mysqlslap 可以用于模拟服务器的负载,并输出计时信息。其被包含在 MySQL 5.1 的发行包中。测试时,可以指定并发连接数,可以指定 SQL 语句。如果没有指定 SQL 语句,mysqlslap 会自动生成查询 schema 的 SELECT 语句。

相关阅读:

mysqlslap 压力测试工具

MySQL自带的性能压力测试工具mysqlslap详解

1. 查看帮助信息。

[root@Betty libmysql]# mysqlslap --help
mysqlslap  Ver 1.0 Distrib 5.6.10, for Linux (x86_64)
Copyright (c) 2005, 2013, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Run a query multiple times against the server.

Usage: mysqlslap [OPTIONS]

默认选项按给定顺序从以下文件中读取:
/etc/my.cnf /etc/mysql/my.cnf /usr/local/mysql/etc/my.cnf ~/.my。 cnf
读取以下组:mysqlslap 客户端
以下选项可以作为第一个参数给出:
--print-defaults        打印程序参数列表并退出。
--no-defaults不要从任何选项文件中读取默认选项,
                        除了登录文件。
--defaults-file=#      只从给定文件中读取默认选项 #.
--defaults-extra-file= # 读取全局文件后读取此文件。
--defaults-group-suffix=#
                        还可以读取带有 concat(group, suffix) 的组
--login-path=#          读取此路径
  -?, --help          显示此帮助并退出。
  -a, --auto-generate-sql 自动生成测试表和数据
                      生成文件或命令未提供的 SQL line.
  --auto-generate-sql-add-autoincrement 增加auto_increment一列
                      向自动生成表添加AUTO_INCREMENT列。
  --auto-generate-sql-execute-number=#自动生成查询的个数
                      设置此数字可生成一组查询
                      运行。
  --auto-generate-sql-guid-primary 增加基于GUID的主键
                     添加基于 GUID 的主要组件自动生成表的键。
  --auto-generate-sql-load-type=name 测试语句的类型。取值包括:read,key,,write,update和mixed(默认)
                      read:查询 write: 插入 key: 读主键 update: 更新主键 mix: 一半插入一半查询
                      指定测试负载类型:mixed、update、write、key、或
                        read;默认为混合。
  --auto-generate-sql-secondary-indexes=# 增加二级索引的个数,默认是0
                      添加到自动生成表中的二级索引数量
                      表。
  --auto-generate-sql-unique-query-number=# 不同查询的数量,默认值为 10
                      为自动测试生成的唯一查询的数量。
  --auto-generate-sql- unique-write-number=# 不同插入的数量,默认是100
                      为
生成的唯一查询的数量                       auto-generate-sql-write-number.
  --auto-generate-sql-write -number=#
                      每个线程执行的行插入数(默认
                      为 100)。
  --commit=#            多少条 DML 后提交一次
                     每 X 条语句提交一次记录。
  -C, --compress          如果服务器和客户端支持都压缩,则压缩信息提交
                      在服务器/客户端协议中使用压缩。
  -c, --concurrency=name 模拟N个客户端并发执行select。可多个指定值,以逗号或者--delimiter 参数指定的值做分隔符
                      要模拟运行查询的客户端数量。
  --create=name      指定用于创建表的.sql文件或者字串
                      用于创建表的文件或字符串。
  --create-schema=name 指定待测试的数据库名,MySQL中schema和数据库,默认是mysqlslap
                      要运行的架构测试。
  --csv[=name]        Generate CSV output to named file or to stdout if no file
                      is named.
  -#, --debug[=#]    This is a non-debug version. Catch this and exit.
  --debug-check      Check memory and open file usage at exit.
  -T, --debug-info    打印内存和CPU的信息
                      Print some debug info at exit.
  --default-auth=name Default authentication client-side plugin to use.
  -F, --delimiter=name 文件中的SQL语句使用分割符号
                      Delimiter to use in SQL statements supplied in file or
                      command line.
  --detach=#          每执行完N个语句,先断开再重新打开连接
                      Detach (close and reopen) connections after X number of
                      requests.
  --enable-cleartext-plugin
                      Enable/disable the clear text authentication plugin.
  -e, --engine=name  创建测试表所使用的存储引擎,可指定多个
                      Storage engine to use for creating the table.
  -h, --host=name    Connect to host.
  -i, --iterations=#  迭代执行的次数
                      Number of times to run the tests.
  --no-drop          Do not drop the schema after the test.
  -x, --number-char-cols=name 自动生成的测试表中包含多少个字符类型的列,默认1
                      Number of VARCHAR columns to create in table if
                      specifying --auto-generate-sql.
  -y, --number-int-cols=name 自动生成的测试表中包含多少个数字类型的列,默认1
                      Number of INT columns to create in table if specifying
                      --auto-generate-sql.
  --number-of-queries=# 总的测试查询次数(并发客户数×每客户查询次数)
                      Limit each client to this number of queries (this is not
                      exact).
  --only-print        只输出模拟执行的结果,不实际执行
                      Do not connect to the databases, but instead print out
                      what would have been done.
  -p, --password[=name]
                      Password to use when connecting to server. If password is
                      not given it's asked from the tty.
  --plugin-dir=name  Directory for client-side plugins.
  -P, --port=#        Port number to use for connection.
  --post-query=name  测试完成以后执行的SQL语句的文件或者字符串 这个过程不影响时间计算
                      Query to run or file containing query to execute after
                      tests have completed.
  --post-system=name  测试完成以后执行的系统语句 这个过程不影响时间计算
                      system() string to execute after tests have completed.
  --pre-query=name    测试执行之前执行的SQL语句的文件或者字符串 这个过程不影响时间计算
                      Query to run or file containing query to execute before
                      running tests.
  --pre-system=name  测试执行之前执行的系统语句 这个过程不影响时间计算
                      system() string to execute before running tests.
  --protocol=name    The protocol to use for connection (tcp, socket, pipe,
                      memory).
  -q, --query=name    指定自定义.sql脚本执行测试。例如可以调用自定义一个存储过程或者sql语句来执行测试
                      Query to run or file containing query to run.
  -s, --silent        不输出
                      Run program in silent mode - no output.
  -S, --socket=name  The socket file to use for connection.
  --ssl              Enable SSL for connection (automatically enabled with
                      other flags).
  --ssl-ca=name      CA file in PEM format (check OpenSSL docs, implies
                      --ssl).
  --ssl-capath=name  CA directory (check OpenSSL docs, implies --ssl).
  --ssl-cert=name    X509 cert in PEM format (implies --ssl).
  --ssl-cipher=name  SSL cipher to use (implies --ssl).
  --ssl-key=name      X509 key in PEM format (implies --ssl).
  --ssl-crl=name      Certificate revocation list (implies --ssl).
  --ssl-crlpath=name  Certificate revocation list path (implies --ssl).
  --ssl-verify-server-cert
                      Verify server's "Common Name" in its cert against
                      hostname used when connecting. This option is disabled by
                      default.
  -u, --user=name    User for login if not current user.
  -v, --verbose      输出更多的信息
                      More verbose output; you can use this multiple times to
                      get even more verbose output.
  -V, --version      Output version information and exit.
[root@Betty libmysql]#

MySQL 压力测试工具 mysqlslap 使用总结

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
如何使用Alter Table语句在MySQL中更改表?如何使用Alter Table语句在MySQL中更改表?Mar 19, 2025 pm 03:51 PM

本文讨论了使用MySQL的Alter Table语句修改表,包括添加/删除列,重命名表/列以及更改列数据类型。

如何为MySQL连接配置SSL/TLS加密?如何为MySQL连接配置SSL/TLS加密?Mar 18, 2025 pm 12:01 PM

文章讨论了为MySQL配置SSL/TLS加密,包括证书生成和验证。主要问题是使用自签名证书的安全含义。[角色计数:159]

您如何处理MySQL中的大型数据集?您如何处理MySQL中的大型数据集?Mar 21, 2025 pm 12:15 PM

文章讨论了处理MySQL中大型数据集的策略,包括分区,碎片,索引和查询优化。

哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什么?哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什么?Mar 21, 2025 pm 06:28 PM

文章讨论了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比较了它们对初学者和高级用户的功能和适合性。[159个字符]

如何使用Drop Table语句将表放入MySQL中?如何使用Drop Table语句将表放入MySQL中?Mar 19, 2025 pm 03:52 PM

本文讨论了使用Drop Table语句在MySQL中放下表,并强调了预防措施和风险。它强调,没有备份,该动作是不可逆转的,详细介绍了恢复方法和潜在的生产环境危害。

您如何用外国钥匙代表关系?您如何用外国钥匙代表关系?Mar 19, 2025 pm 03:48 PM

文章讨论了使用外国密钥来代表数据库中的关系,重点是最佳实践,数据完整性和避免的常见陷阱。

如何在JSON列上创建索引?如何在JSON列上创建索引?Mar 21, 2025 pm 12:13 PM

本文讨论了在PostgreSQL,MySQL和MongoDB等各个数据库中的JSON列上创建索引,以增强查询性能。它解释了索引特定的JSON路径的语法和好处,并列出了支持的数据库系统。

如何保护MySQL免受常见漏洞(SQL注入,蛮力攻击)?如何保护MySQL免受常见漏洞(SQL注入,蛮力攻击)?Mar 18, 2025 pm 12:00 PM

文章讨论了使用准备好的语句,输入验证和强密码策略确保针对SQL注入和蛮力攻击的MySQL。(159个字符)

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。