文章目录
- 简介
- 一.实例说明
- 二.参数说明
简介
mysqlslap是一个诊断程序,旨在模拟MySQL服务器的客户端负载并报告每个阶段的时间。它就像多个客户端正在访问服务器一样工作。
像这样 调用mysqlslap(windows下调用powershell或者cmd窗口,linux直接运行命令即可):
shell> mysqlslap [options]
- 一些选项,例如–create 或–query使您能够指定包含SQL语句的字符串或包含语句的文件。
- 如果指定文件,则默认情况下该文件每行必须包含一个语句。(也就是说,隐式语句定界符是换行符。)使用该 --delimiter选项可以指定其他定界符,这使您可以指定跨越多行的语句或将多条语句放在一行上。您不能在文件中包含注释; mysqlslap无法理解它们。
mysqlslap分三个阶段运行:
- 创建架构,表以及可选的任何存储程序或数据以用于测试。此阶段使用单个客户端连接。
- 运行负载测试。此阶段可以使用许多客户端连接。
- 清理(断开连接,如果指定的话,删除表)。此阶段使用单个客户端连接。
一.实例说明
例子:
提供您自己的create和query SQL语句,其中包含50个客户端查询和200个选择(在一行中输入命令):
mysqlslap --delimiter=";"
--create="CREATE TABLE a (b int);INSERT INTO a VALUES (23)"
--query="SELECT * FROM a" --concurrency=50 --iterations=200
让mysqlslap用两INT列和三VARCHAR列的表构建查询SQL语句。使用五个客户端,每个客户端查询20次。不要创建表或插入数据(即,使用先前测试的架构和数据):
mysqlslap --concurrency=5 --iterations=20
--number-int-cols=2 --number-char-cols=3
--auto-generate-sql
告诉程序从指定的文件加载创建,插入和查询SQL语句,其中该 create.sql文件包含多个以分隔的表创建语句’;‘和多个以分隔的插入语句’;’。该 --query文件将包含多个以分隔的查询’;’。运行所有装入语句,然后使用五个客户端(每个客户端五次)运行查询文件中的所有查询:
mysqlslap --concurrency=5
--iterations=5 --query=query.sql --create=create.sql
--delimiter=";"
二.参数说明
mysqlslap选项
选项名称 | 描述 | 版本起止 |
---|---|---|
- -auto-generate-sql | 命令选项未提供或未使用文件时自动生成SQL语句 | |
- -auto-generate-sql-add-autoincrement | 在自动生成的表中增加自增列 | |
- -auto-generate-sql-execute-number | 指定自动生成多少个查询 | |
- -auto-generate-sql-guid-primary | 将基于GUID的主键添加到自动生成的表中 | |
- -auto-generate-sql-load-type | 指定测试负载类型 | |
- -auto-generate-sql-secondary-indexes | 指定要添加到自动生成的表中的二级索引的数量 | |
- -auto-generate-sql-unique-query-number | 为自动测试生成多少个不同的查询。 | |
- -auto-generate-sql-unique-query-number | 为自动测试生成多少个不同的插入。 | |
- -auto-generate-sql-write-number | 每个线程要执行多少行插入 | |
- -commit | 提交前要执行多少条语句 | |
- -compress | 压缩客户端和服务器之间发送的所有信息 | |
- -create | 包含用于创建表的语句的文件或字符串 | |
- -create-schema | 运行测试的模式 | |
- -debug | 写调试日志 | |
- -debug-check | 程序退出时,打印一些调试信息 | |
- -debug-info | 程序退出时,打印调试信息以及内存和CPU使用情况统计信息 | |
- -delimiter | 在文件或使用命令选项提供的SQL语句中使用的定界符 | |
- -detach | 在每个N语句之后分离(关闭并重新打开)每个连接 | |
- -engine | 测试表的存储引擎 | |
- -host | 连接到给定主机上的MySQL服务器。 | |
- -iterations | 运行测试的次数。 | |
- -number-char-cols | 指定了–auto-generate-sql自定义VARCHAR的列数 | |
- -number-int-cols | 指定了–auto-generate-sql自定义INT的列数 | |
- -number-of-queries | 将每个客户端限制为大约这么多查询 | |
- -password | 用于连接服务器的MySQL帐户的密码 | |
- -port | 对于TCP / IP连接,使用的端口号 | |
- -query | 包含SELECT用于检索数据的语句的文件或字符串 。 | |
- -user | 用于连接到服务器的MySQL帐户的用户名 | |
- -version | 显示版本信息并退出。 |
官方文档地址:https://dev.mysql.com/doc/refman/5.6/en/mysqlslap.html
给出mysql自动生成的命令语句的excel工具:https://download.csdn.net/download/colcool/11745630
详细参数及可选项如下:
- –help, -?
显示帮助消息并退出。
- –auto-generate-sql, -a
当文件中未提供或使用命令选项时,会自动生成SQL语句。
- –auto-generate-sql-add-autoincrement
AUTO_INCREMENT在自动生成的表中 添加一列。
- –auto-generate-sql-execute-number=N
指定要自动生成的查询数。
- –auto-generate-sql-guid-primary
将基于GUID的主键添加到自动生成的表中。
- –auto-generate-sql-load-type=type
指定测试负载类型。允许值为 read(扫描表), write(插入表中), key(读取主键), update(更新主键)或 mixed(半插入,半扫描选择)。默认值为mixed。
- –auto-generate-sql-secondary-indexes=N
指定要添加到自动生成的表中的二级索引的数量。默认情况下,不添加任何内容。
- –auto-generate-sql-unique-query-number=N
为自动测试生成多少个不同的查询。例如,如果您运行key执行1000个选择的测试,则可以将该选项的值设置为1000来运行1000个唯一查询,或者使用值50的选项来执行50个不同的选择。预设值为10。
- –auto-generate-sql-unique-write-number=N
要为生成多少个不同的查询 --auto-generate-sql-write-number。预设值为10。
- –auto-generate-sql-write-number=N
要执行多少行插入。默认值为100。
- –commit=N
提交前要执行多少条语句。默认值为0(不执行任何提交)。
- –compress, -C
尽可能压缩客户端和服务器之间发送的所有信息。请参见 第4.2.5节“连接压缩控制”。
- –concurrency=N, -c N
要模拟的并行客户端的数量。
- –create=value
包含用于创建表的语句的文件或字符串。
- –create-schema=value
运行测试的模式。
注意
如果–auto-generate-sql 还提供了该 选项,则mysqlslap将在测试运行结束时删除该架构。为避免这种情况,请同时使用该–no-drop选项。
- –csv[=file_name]
生成以逗号分隔的值格式的输出。输出将转到指定的文件,如果未提供文件,则转到标准输出。
- –debug[=debug_options], -# [debug_options]
编写调试日志。典型的 debug_options字符串是 。默认值为 。 d:t:o,file_named:t:o,/tmp/mysqlslap.trace
- –debug-check
程序退出时,打印一些调试信息。
- –debug-info, -T
程序退出时,打印调试信息以及内存和CPU使用情况统计信息。
- –default-auth=plugin
有关使用哪个客户端身份验证插件的提示。请参见第6.2.11节“可插入身份验证”。
- –defaults-extra-file=file_name
在全局选项文件之后但在用户选项文件之前(在Unix上)读取此选项文件。如果文件不存在或无法访问,则发生错误。 file_name如果给出为相对路径名而不是完整路径名,则相对于当前目录解释。
有关此选项和其他选项文件选项的更多信息,请参见第4.2.2.3节“影响选项文件处理的命令行选项”。
- –defaults-file=file_name
仅使用给定的选项文件。如果文件不存在或无法访问,则发生错误。 file_name如果给出为相对路径名而不是完整路径名,则相对于当前目录解释。
例外:即使这样–defaults-file,客户端程序也会 读取.mylogin.cnf。
有关此选项和其他选项文件选项的更多信息,请参见第4.2.2.3节“影响选项文件处理的命令行选项”。
- –defaults-group-suffix=str
不仅阅读常规选项组,而且阅读具有常规名称和后缀的组 str。例如, mysqlslap通常读取 [client]和 [mysqlslap]组。如果–defaults-group-suffix=_other 给出了该 选项,mysqlslap也会读取 [client_other]和 [mysqlslap_other]组。
有关此选项和其他选项文件选项的更多信息,请参见第4.2.2.3节“影响选项文件处理的命令行选项”。
- –delimiter=str, -F str
在文件或使用命令选项提供的SQL语句中使用的定界符。
- –detach=N
在每个N语句之后分离(关闭并重新打开)每个连接 。缺省值为0(连接不分离)。
- –enable-cleartext-plugin
启用mysql_clear_password明文身份验证插件。(请参见 第6.4.1.5节“客户端明文可插入身份验证”。)
- –engine=engine_name, -e engine_name
用于创建表的存储引擎。
- –host=host_name, -h host_name
连接到给定主机上的MySQL服务器。
- –iterations=N, -i N
运行测试的次数。
- –login-path=name
从.mylogin.cnf登录路径文件中的命名登录路径读取选项 。阿 “ 登录路径 ”是含有指定要连接到哪个MySQL服务器和选项哪个帐户作为认证选项组。要创建或修改登录路径文件,请使用 mysql_config_editor实用程序。请参见 第4.6.6节“ mysql_config_editor -MySQL配置实用程序”。
有关此选项和其他选项文件选项的更多信息,请参见第4.2.2.3节“影响选项文件处理的命令行选项”。
- –no-drop
防止mysqlslap删除它在测试运行期间创建的任何模式。
- –no-defaults
不要读取任何选项文件。如果由于从选项文件中读取未知选项而导致程序启动失败,–no-defaults则可以使用该选项 来防止读取它们。
唯一的例外是,.mylogin.cnf 在所有情况下都会读取该文件(如果存在)。这样,即使–no-defaults使用密码,也可以通过比命令行更安全的方式指定密码 。(.mylogin.cnf由mysql_config_editor实用程序创建 。请参见 第4.6.6节“ mysql_config_editor -MySQL配置实用程序”。)
有关此选项和其他选项文件选项的更多信息,请参见第4.2.2.3节“影响选项文件处理的命令行选项”。
- –number-char-cols=N, -x N
指定了VARCHAR要使用 的列 数–auto-generate-sql。
- –number-int-cols=N, -y N
指定了INT要使用 的列数–auto-generate-sql。
- –number-of-queries=N
将每个客户端限制为大约这么多查询。查询计数考虑了语句定界符。例如,如果您按如下方式调用mysqlslap,;则会识别定界符,以便查询字符串的每个实例都计为两个查询。结果,插入了5行(不是10行)。
shell> mysqlslap --delimiter=";" --number-of-queries=10
–query=“use test;insert into t values(null)”
- –only-print
不要连接到数据库。mysqlslap 只打印它会做的事情。
- –password[=password], -p[password]
用于连接服务器的MySQL帐户的密码。密码值是可选的。如果未给出,则 mysqlslap提示输入一个。如果提供,则或 和后面的密码之间 必须没有空格。如果未指定密码选项,则默认为不发送密码。 --password=-p
在命令行上指定密码应该被认为是不安全的。为避免在命令行上输入密码,请使用选项文件。请参见 第6.1.2.1节“最终用户密码安全准则”。
要明确指定没有密码,并且mysqlslap不应提示输入密码 ,请使用该 --skip-password 选项。
- –pipe, -W
在Windows上,使用命名管道连接到服务器。仅当服务器在named_pipe启用系统变量以支持命名管道连接的情况下启动时,此选项才适用 。另外,建立连接的用户必须是named_pipe_full_access_group 系统变量指定的Windows组的成员 。
- –plugin-dir=dir_name
在其中查找插件的目录。如果该–default-auth选项用于指定身份验证插件,但 mysqlslap找不到,请指定此选项 。请参见 第6.2.11节“可插入身份验证”。
- –port=port_num, -P port_num
对于TCP / IP连接,使用的端口号。
- –post-query=value
测试完成后包含要执行的语句的文件或字符串。此执行不计入计时目的。
- –post-system=str
system() 测试完成后 要使用的字符串。此执行不计入计时目的。
- –pre-query=value
包含要在运行测试之前执行的语句的文件或字符串。此执行不计入计时目的。
- –pre-system=str
system() 运行测试之前 要使用的字符串。此执行不计入计时目的。
- –print-defaults
打印程序名称及其从选项文件中获取的所有选项。
有关此选项和其他选项文件选项的更多信息,请参见第4.2.2.3节“影响选项文件处理的命令行选项”。
- –protocol={TCP|SOCKET|PIPE|MEMORY}
用于连接到服务器的连接协议。当其他连接参数通常导致使用所需协议以外的协议时,此功能很有用。有关允许值的详细信息,请参见 第4.2.4节“使用命令选项连接到MySQL服务器”。
- –query=value, -q value
包含SELECT用于检索数据的语句的文件或字符串 。
- –secure-auth
不要以旧(4.1之前)格式向服务器发送密码。这样可以防止除使用较新密码格式的服务器以外的其他连接。默认情况下启用此选项。用于 --skip-secure-auth 禁用它。该选项是在MySQL 5.6.17中添加的。
注意
使用4.1之前的哈希方法的密码比使用本机密码哈希方法的密码安全性较低,应避免使用。不建议使用4.1之前的密码,并且在将来的MySQL版本中将删除对密码的支持。有关帐户升级的说明,请参见第6.4.1.3节“从4.1之前的密码哈希和mysql_old_password插件迁移”。
注意
此选项已被弃用,并将在以后的版本中删除。从MySQL 5.7.5开始,它始终处于启用状态,尝试禁用它会产生错误。
- –shared-memory-base-name=name
在Windows上,共享内存名称,用于使用共享内存与本地服务器建立的连接。默认值为MYSQL。共享内存名称区分大小写。
仅当服务器在shared_memory启用系统变量以支持共享内存连接的情况下启动时,此选项才适用 。
- –silent, -s
静音模式。无输出。
- –socket=path, -S path
对于与的连接localhost,要使用的Unix套接字文件,或者在Windows上,要使用的命名管道的名称。
在Windows上,仅当在named_pipe 启用了支持命名管道连接的系统变量的情况下启动服务器时,此选项才适用。另外,建立连接的用户必须是named_pipe_full_access_group 系统变量指定的Windows组的成员 。
- –ssl*
以开头的选项 --ssl指定是否使用SSL连接到服务器,并指示在何处查找SSL密钥和证书。请参阅 加密连接的命令选项。
- –user=user_name, -u user_name
用于连接到服务器的MySQL帐户的用户名。
- –verbose, -v
详细模式。打印有关程序功能的更多信息。可以多次使用此选项以增加信息量。
- –version, -V
显示版本信息并退出。
参考信息:https://blog.csdn.net/colcool/article/details/100841517