13.7.5.30 SHOW PROFILE 语句

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
}

SHOW PROFILESHOW PROFILES语句显示概要信息,该信息指示在当前会话过程中执行的语句的资源使用情况。

Note

SHOW PROFILESHOW PROFILES语句已弃用,并将在以后的 MySQL 版本中删除。使用Performance Schema代替;参见第 25.19.1 节“使用性能模式进行查询分析”

要控制性能分析,请使用profiling会话变量,该变量的默认值为 0(OFF)。通过将profiling设置为 1 或ON来启用性能分析:

mysql> SET profiling = 1;

SHOW PROFILES显示发送到服务器的最新语句的列 table。列 table 的大小由profiling_history_size会话变量控制,该变量的默认值为 15.最大值为 100.将值设置为 0 具有禁用分析的实际效果。

SHOW PROFILESHOW PROFILES之外,所有语句均已概要分析,因此您在概要文件列 table 中都找不到这两个语句。分析格式错误的语句。例如,SHOW PROFILING是非法语句,如果尝试执行它会发生语法错误,但是它将显示在配置文件列 table 中。

SHOW PROFILE显示有关单个语句的详细信息。如果没有FOR QUERY n子句,则输出与最近执行的语句有关。如果包含FOR QUERY n,则SHOW PROFILE显示有关语句* n *的信息。 * n *的值对应于SHOW PROFILES显示的Query_ID值。

可以提供LIMIT row_count子句以将输出限制为* row_count 行。如果给定LIMIT,则可以添加OFFSET offset以将输出 offset *行开始到整个行集中。

默认情况下,SHOW PROFILE显示StatusDuration列。 Status值类似于SHOW PROCESSLIST显示的State值,尽管对于某些状态值,这两个语句的解释可能会有一些细微的差异(请参见第 8.14 节“检查服务器线程(进程)信息”)。

可以指定可选的type *值以显示特定的其他信息类型:

  • ALL显示所有信息

  • BLOCK IO显示块 Importing 和输出操作的计数

  • CONTEXT SWITCHES显示自愿和非自愿上下文切换的计数

  • CPU显示用户和系统 CPU 使用时间

  • IPC显示已发送和已接收邮件的计数

  • MEMORY当前未实现

  • PAGE FAULTS显示主要和次要页面错误的计数

  • SOURCE显示源代码中的函数名称以及该函数所在文件的名称和行号

  • SWAPS显示掉期计数

每个会话均启用分析。会话结束时,其分析信息将丢失。

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)

Note

在某些体系结构上,性能分析仅部分起作用。对于取决于getrusage()系统调用的值,在 Windows 等不支持该调用的系统上返回NULL。此外,性能分析是按进程而不是每个线程进行的。这意味着服务器中除您自己以外的线程上的活动可能会影响您看到的计时信息。

INFORMATION_SCHEMA PROFILINGtable 中也提供了分析信息。参见第 24.19 节“ INFORMATION_SCHEMA PROFILINGtable”。例如,以下查询是等效的:

SHOW PROFILE FOR QUERY 2;

SELECT STATE, FORMAT(DURATION, 6) AS DURATION
FROM INFORMATION_SCHEMA.PROFILING
WHERE QUERY_ID = 2 ORDER BY SEQ;