SHOW PROFILE [type [, type] ... ]
[FOR QUERY n]
[LIMIT row_count [OFFSET offset]]
type: {
ALL
| BLOCK IO
| CONTEXT SWITCHES
| CPU
| IPC
| MEMORY
| PAGE FAULTS
| SOURCE
| SWAPS
}
该 显示 PROFILE
和 显示 PROFILES
语句显示当前会话中执行的语句的资源使用情况信息。
该 显示 PROFILE
和 显示 PROFILES
语句已弃用;预计在未来 MySQL 版本中删除它们。请改用 性能架构;见 第 29.19.1 节,“使用性能架构进行查询分析”。
要控制 profiling,请使用 profiling
会话变量,其默认值为 0 (OFF
)。通过将 profiling
设置为 1 或 ON
来启用 profiling:
mysql> SET profiling = 1;
显示 PROFILES
显示最近发送到服务器的语句列表。该列表的大小由 profiling_history_size
会话变量控制,默认值为 15。最大值为 100。将值设置为 0 实际上禁用了 profiling。
除了 显示 PROFILE
和 显示 PROFILES
之外的所有语句都被 profiled。因此,两个语句都不会出现在 profile 列表中。格式错误的语句也被 profiled。例如,SHOW PROFILING
是一个非法语句,如果尝试执行它,将出现语法错误,但它将出现在 profiling 列表中。
显示 PROFILE
显示单个语句的详细信息。没有 FOR QUERY
子句时,输出适用于最近执行的语句。如果包括 n
FOR QUERY
,n
显示 PROFILE
显示语句 n
的信息。n
的值对应于 显示 PROFILES
显示的 Query_ID
值。
可以使用 LIMIT
子句来限制输出到 row_count
row_count
行。如果给出了 LIMIT
,则可以添加 OFFSET
来从完整的行集开始输出 offset
offset
行。
默认情况下,显示 PROFILE
显示 Status
和 Duration
列。状态值类似于 显示 PROCESSLIST
显示的 State
值,尽管对于两个语句的一些状态值可能存在一些小的解释差异(见 第 10.14 节,“检查服务器线程(进程)信息”)。
可以指定可选的 type
值来显示特定的附加信息:
-
ALL
显示所有信息 -
BLOCK IO
显示块输入和输出操作的计数 -
CONTEXT SWITCHES
显示自愿和非自愿上下文切换的计数 -
CPU
显示用户和系统 CPU 使用时间 -
IPC
显示发送和接收消息的计数 -
MEMORY
目前未实现 -
页面错误
显示主要和次要页面错误的计数 -
来源
显示源代码中的函数名称,连同函数所在文件的名称和行号 -
交换
显示交换计数
配置文件是每个会话启用的。当会话结束时,其配置信息将丢失。
mysql> SELECT @@profiling;
+-------------+
| @@profiling |
+-------------+
| 0 |
+-------------+
1 row in set (0.00 sec)
mysql> SET profiling = 1;
Query OK, 0 rows affected (0.00 sec)
mysql> DROP TABLE IF EXISTS t1;
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> CREATE TABLE T1 (id INT);
Query OK, 0 rows affected (0.01 sec)
mysql> SHOW PROFILES;
+----------+----------+--------------------------+
| Query_ID | Duration | Query |
+----------+----------+--------------------------+
| 0 | 0.000088 | SET PROFILING = 1 |
| 1 | 0.000136 | DROP TABLE IF EXISTS t1 |
| 2 | 0.011947 | CREATE TABLE t1 (id INT) |
+----------+----------+--------------------------+
3 rows in set (0.00 sec)
mysql> SHOW PROFILE;
+----------------------+----------+
| Status | Duration |
+----------------------+----------+
| checking permissions | 0.000040 |
| creating table | 0.000056 |
| After create | 0.011363 |
| query end | 0.000375 |
| freeing items | 0.000089 |
| logging slow query | 0.000019 |
| cleaning up | 0.000005 |
+----------------------+----------+
7 rows in set (0.00 sec)
mysql> SHOW PROFILE FOR QUERY 1;
+--------------------+----------+
| Status | Duration |
+--------------------+----------+
| query end | 0.000107 |
| freeing items | 0.000008 |
| logging slow query | 0.000015 |
| cleaning up | 0.000006 |
+--------------------+----------+
4 rows in set (0.00 sec)
mysql> SHOW PROFILE CPU FOR QUERY 2;
+----------------------+----------+----------+------------+
| Status | Duration | CPU_user | CPU_system |
+----------------------+----------+----------+------------+
| checking permissions | 0.000040 | 0.000038 | 0.000002 |
| creating table | 0.000056 | 0.000028 | 0.000028 |
| After create | 0.011363 | 0.000217 | 0.001571 |
| query end | 0.000375 | 0.000013 | 0.000028 |
| freeing items | 0.000089 | 0.000010 | 0.000014 |
| logging slow query | 0.000019 | 0.000009 | 0.000010 |
| cleaning up | 0.000005 | 0.000003 | 0.000002 |
+----------------------+----------+----------+------------+
7 rows in set (0.00 sec)
在某些架构上,配置文件仅部分功能。对于依赖 getrusage()
系统调用的值,在不支持该调用的系统上,如 Windows,将返回 NULL
。此外,配置文件是按进程而不是按线程的。这意味着服务器中其他线程的活动可能会影响您看到的计时信息。
配置信息也可以从 INFORMATION_SCHEMA
配置
表中获得。见 第 28.3.24 节,“INFORMATION_SCHEMA 配置表”。例如,以下查询是等效的:
SHOW PROFILE FOR QUERY 2;
SELECT STATE, FORMAT(DURATION, 6) AS DURATION
FROM INFORMATION_SCHEMA.PROFILING
WHERE QUERY_ID = 2 ORDER BY SEQ;