MySQL Performance Schema 详解及运行时配置优化

请在此添加图片描述

引言

MySQL 的 Performance Schema 是一套性能监控与诊断工具,帮助开发者和数据库管理员收集、分析 MySQL 实例的运行状态,找出性能瓶颈并进行优化。通过 Performance Schema,我们能够监控不同的内部事件、线程、会话、语句执行等关键性能指标。然而,默认情况下并非所有监控项目都被启用,用户可以通过配置相关的表来灵活调整需要采集的监控数据。

本文将对 Performance Schema 相关的运行时配置表进行深入剖析,包括 performance_timerssetup_timerssetup_consumerssetup_instrumentssetup_actorssetup_objectsthreads 表的具体作用、字段含义及其配置技巧,帮助读者更好地掌握和使用 MySQL 性能调优工具。

为什么需要运行时配置?

在实际应用中,我们可能会遇到以下需求:

  • 修改默认配置:有时启动时默认配置未能启用所有需要的监控项。此时需要在运行时动态调整配置,以便捕捉到更多的性能数据。
  • 高并发场景:在高负载情况下,数据库生成了大量的事件信息。如果我们只对某些特定会话或事件感兴趣,可以在运行时调整配置,以避免数据过多导致性能问题。

通过运行时配置,我们可以更灵活地管理 Performance Schema 的数据采集和存储,从而更好地满足实际监控需求。

关键配置表及字段解释

以下是 MySQL 5.8 中与 Performance Schema 配置相关的一些重要表及其字段解释:

performance_timers 表详解

在 MySQL 中,performance_timers 表用于显示各种计时器的配置和性能参数。了解这些计时器对于精确地测量和记录性能数据至关重要。以下是 performance_timers 表中各字段的详细解释:

请在此添加图片描述

表结构

mysql> SELECT * FROM performance_timers;
+-------------+-----------------+------------------+----------------+
| TIMER_NAME  | TIMER_FREQUENCY | TIMER_RESOLUTION | TIMER_OVERHEAD |
+-------------+-----------------+------------------+----------------+
| CYCLE       |      3791482587 |                1 |             22 |
| NANOSECOND  |      1000000000 |                1 |             44 |
| MICROSECOND |         1000000 |                1 |             36 |
| MILLISECOND |            1037 |                1 |             36 |
| TICK        |             105 |                1 |            596 |
+-------------+-----------------+------------------+----------------+
5 rows in set

字段解释

TIMER_NAME:计时器的名称。这些名称指代不同的时间度量方式或精度,例如 NANOSECOND 表示纳秒级别的计时器,MILLISECOND 表示毫秒级别的计时器。

TIMER_FREQUENCY:计时器的频率,以每秒计数的次数表示。例如,NANOSECOND 的频率为 1000000000,意味着每秒有 10 亿次计数。CYCLE 的频率为 3791482587,意味着每秒可以测量约 37 亿次。

TIMER_RESOLUTION:计时器的分辨率,表示计时器的最小单位。在 MySQL 中,这通常是 1,即每个计时器的最小单位是一个基本计数。所有计时器的 TIMER_RESOLUTION 为 1,表明它们的分辨率相同,能够测量最小的时间单位。

TIMER_OVERHEAD:使用该计时器时的开销,以微秒为单位。开销越低,计时器的性能越高。TICK 计时器的开销为 596 微秒,相对较高,这表明它可能在时间测量过程中引入了较大的性能开销。相比之下,NANOSECOND 计时器的开销为 44 微秒,性能较好。

使用场景

  • 选择合适的计时器:根据性能需求选择不同的计时器。例如,如果需要高精度的性能数据,可以选择 NANOSECOND 计时器;如果性能开销更重要,可以选择开销较低的计时器,如 MICROSECOND
  • 优化性能:了解计时器的开销可以帮助我们优化性能。例如,在高负载场景下,可以选择开销更低的计时器,以减少对系统性能的影响

setup_timers 表详解

请在此添加图片描述

在 MySQL 中,setup_timers 表用于配置 Performance Schema 的计时器。计时器的配置决定了性能数据的测量精度。通过配置 setup_timers 表中的计时器,我们可以根据不同事件的需求选择适当的计时器类型。这种灵活的配置可以帮助我们在性能监控中取得更好的效果,既可以提高数据的精度,也可以减少性能开销。了解这些配置能够帮助优化 Performance Schema 的性能监控,使其更好地适应具体需求。

表结构

mysql> SELECT * FROM setup_timers;
+-------------+-------------+
| NAME        | TIMER_NAME  |
+-------------+-------------+
| idle        | MICROSECOND |
| wait        | CYCLE       |
| stage       | NANOSECOND  |
| statement   | NANOSECOND  |
| transaction | NANOSECOND  |
+-------------+-------------+
5 rows in set

字段解释

NAME: 计时器类别的名称。这个字段表示 Performance Schema 用于不同类型事件的计时器配置。idle 表示空闲事件的计时器,wait 表示等待事件的计时器,stage 表示阶段事件的计时器。

TIMER_NAME: 与 performance_timers 表中的计时器名称匹配,表示用于记录该事件类别的计时器类型。MICROSECOND 表示微秒级计时器,NANOSECOND 表示纳秒级计时器,CYCLE 表示周期计时器。

配置说明

  • idle 计时器:使用 MICROSECOND 计时器。
    • 应用:适用于记录空闲时间事件,如服务器闲置时间的精确测量。如果关心系统空闲时间的精确度,可以选择 MICROSECOND 计时器来捕捉更详细的时间数据。
  • wait 计时器:使用 CYCLE 计时器。
    • 应用:用于记录等待事件,如等待锁或 I/O 操作的时间。如果的应用程序经常出现等待操作,选择 CYCLE 计时器可以减少计时器开销,提高性能。
  • stage 计时器:使用 NANOSECOND 计时器。
    • 应用:用于记录 SQL 执行阶段的时间,例如从解析到执行的各个阶段。在分析复杂的 SQL 查询性能时,使用 NANOSECOND 计时器可以提供更高的精度,以便更详细地了解每个阶段的耗时。
  • statement 计时器: 使用 NANOSECOND 计时器。
    • 应用:用于记录 SQL 语句的执行时间,包括语句的总执行时间。当需要监控单个 SQL 语句的执行性能时,使用 NANOSECOND 计时器能够提供极高的精确度。
  • transaction 计时器:使用 NANOSECOND 计时器。
    • 应用:用于记录事务的执行时间,包括事务的开始和结束时间。对于涉及大量事务的应用,使用 NANOSECOND 计时器可以帮助精确分析事务的执行性能。

查看当前计时器配置:

SELECT * FROM setup_timers;

更改计时器配置,例如,将 statement 事件的计时器更改为 MICROSECOND

UPDATE setup_timers SET TIMER_NAME = 'MICROSECOND' WHERE NAME = 'statement';

setup_consumers 表详解

请在此添加图片描述

在 MySQL 中,setup_consumers 表用于配置 Performance Schema 中的消费者。消费者负责从 Performance Schema 中收集并存储性能事件数据。通过配置消费者的启用状态,我们可以灵活地控制哪些类型的数据被记录和分析。通过配置 setup_consumers 表中的消费者,可以精确控制哪些性能数据被记录和分析。这种灵活的配置能够根据具体需求优化 Performance Schema 的性能监控。启用或禁用特定的消费者可以使更有效地收集和分析性能数据,从而提高数据库系统的整体性能和可靠性。

表结构

mysql> SELECT * FROM setup_consumers;
+----------------------------------+---------+
| NAME                             | ENABLED |
+----------------------------------+---------+
| events_stages_current            | NO      |
| events_stages_history            | NO      |
| events_stages_history_long       | NO      |
| events_statements_current        | YES     |
| events_statements_history        | YES     |
| events_statements_history_long   | NO      |
| events_transactions_current      | NO      |
| events_transactions_history      | NO      |
| events_transactions_history_long | NO      |
| events_waits_current             | NO      |
| events_waits_history             | NO      |
| events_waits_history_long        | NO      |
| global_instrumentation           | YES     |
| thread_instrumentation           | YES     |
| statements_digest                | YES     |
+----------------------------------+---------+
15 rows in set

字段解释

NAME: 消费者的名称。每个消费者对应 Performance Schema 中的一个数据类型,它决定了如何收集和存储不同类型的性能事件数据。events_statements_current 记录当前正在执行的 SQL 语句的事件,global_instrumentation 用于全局性能统计。

ENABLED: 指示相应的消费者是否启用(YES 或 NO)。如果启用,消费者将开始收集相应类型的事件数据;如果禁用,则不会收集这些数据。events_statements_current 的状态为 YES,说明当前正在记录 SQL 语句的执行事件,而 events_stages_current 的状态为 NO,则表示当前不记录 SQL 执行阶段的事件。

消费者配置说明

  • events_stages_current: NO,用于记录当前 SQL 语句执行的阶段事件。由于它未启用,当前不会收集这些数据。
  • events_statements_current: YES,用于记录当前正在执行的 SQL 语句事件。这有助于实时监控 SQL 执行情况。如果需要了解当前正在执行的 SQL 语句及其性能,可以启用此消费者。
  • global_instrumentation: YES,用于记录全局性能统计信息,如锁的使用情况、文件 I/O 操作等。启用此消费者可以帮助我们获得整体系统的性能概况,从而进行更高效的性能优化。
  • statements_digest: YES,用于记录 SQL 语句的摘要信息,这有助于分析和汇总 SQL 语句的性能。如果需要对执行的 SQL 语句进行汇总和分析,可以启用此消费者,以便获取 SQL 语句的统计信息。

查看当前消费者的配置状态:

SELECT * FROM setup_consumers;

启用 events_stages_current 消费者:

UPDATE setup_consumers SET ENABLED = 'YES' WHERE NAME = 'events_stages_current';

禁用 events_statements_current 消费者:

UPDATE setup_consumers SET ENABLED = 'NO' WHERE NAME = 'events_statements_current';

setup_instruments 表详解

在 MySQL 的 Performance Schema 中,setup_instruments 表用于配置各种性能事件的采集器。通过设置这些采集器,我们可以控制哪些类型的事件会被记录,它允许根据需求选择要监控的具体事件,决定是否记录时间数据,从而优化性能监控的效果和开销。通过对该表的配置,可以灵活地控制性能监控的粒度和范围,确保监控信息对系统优化和问题排查的价值最大化。

表结构

数据太多了,我们挑重点的说,我们假设执行了之后的查询:

mysql> SELECT * FROM setup_instruments;
+--------------------------------------------------------------------------------+---------+--------+
| NAME                                                                           | ENABLED | TIMED  |
+--------------------------------------------------------------------------------+---------+--------+
| wait/synch/mutex/sql/LOCK_error_log                                            | NO      | NO    |
| wait/synch/mutex/sql/LOCK_gdl                                                  | NO      | NO    |
| wait/synch/mutex/sql/LOCK_global_system_variables                              | NO      | NO    |
| wait/synch/mutex/sql/LOCK_manager                                              | NO      | NO    |
| wait/synch/mutex/sql/LOCK_prepared_stmt_count                                  | NO      | NO    |
| wait/synch/mutex/sql/LOCK_sql_slave_skip_counter                               | NO      | NO    |
| wait/synch/mutex/sql/LOCK_slave_net_timeout                                    | NO      | NO    |
| wait/synch/mutex/sql/LOCK_slave_trans_dep_tracker                              | NO      | NO    |
| wait/synch/mutex/sql/LOCK_server_started                                       | NO      | NO    |
| wait/synch/mutex/sql/LOCK_keyring_operations                                   | NO      | NO    |
| wait/synch/mutex/sql/LOCK_socket_listener_active                               | NO      | NO    |
+--------------------------------------------------------------------------------+---------+--------+
................

字段解释

NAME: 表示要监控的特定事件或操作的名称。它通常包括事件的类别(如 wait/synch/mutex/sql)以及具体的资源(如 LOCK_error_log)。wait/synch/mutex/sql/LOCK_error_log 代表 SQL 线程在获取错误日志锁时的等待情况。

ENABLED: 指示是否启用该监控仪器(YES 或 NO)。如果为 YES,表示该监控工具正在采集数据;如果为 NO,则不采集数据。NO 表示 LOCK_error_log 不在监控范围内;YES 表示 LOCK_global_system_variables 在监控范围内。

TIMED: 指示是否记录时间数据(YES 或 NO)。如果为 YES,表示除了记录事件本身外,还记录发生该事件所花费的时间;如果为 NO,则只记录事件发生情况。NO 表示 LOCK_error_log 事件的发生时间不会被记录;YES 表示 LOCK_global_system_variables 事件的发生时间会被记录。

查看所有启用的监控仪器:

SELECT * FROM setup_instruments WHERE ENABLED = 'YES';

查看记录时间信息的所有监控仪器:

SELECT * FROM setup_instruments WHERE TIMED = 'YES';

启用某个监控仪器,例如启用 LOCK_error_log 并记录时间:

UPDATE setup_instruments SET ENABLED = 'YES', TIMED = 'YES' WHERE NAME = 'wait/synch/mutex/sql/LOCK_error_log';

禁用某个监控仪器,例如禁用 LOCK_global_system_variables

UPDATE setup_instruments SET ENABLED = 'NO' WHERE NAME = 'wait/synch/mutex/sql/LOCK_global_system_variables';

setup_actors 表详解

请在此添加图片描述

在 MySQL 的 Performance Schema 中,setup_actors 表用于配置和管理对性能数据的访问控制。通过设置这个表,可以决定哪些主机、用户和角色能够查看和收集特定的性能事件数据。通过配置 setup_actors 表中的字段,可以精确控制哪些主机、用户和角色能够访问和收集 Performance Schema 中的性能数据。正确设置这些访问控制配置可以确保性能数据的安全性和隐私性,同时也允许根据需要收集和分析性能数据。理解这些配置项能够帮助更好地管理和优化 MySQL 数据库的性能监控。

表结构

mysql> SELECT * FROM setup_actors;
+------+------+------+---------+---------+
| HOST | USER | ROLE | ENABLED | HISTORY |
+------+------+------+---------+---------+
| %    | %    | %    | YES     | YES     |
+------+------+------+---------+---------+
1 row in set

字段解释

HOST: 指定能够访问性能数据的主机地址。可以是具体的 IP 地址、主机名或通配符。% 表示允许所有主机访问性能数据;192.168.1.% 表示只允许 192.168.1.x 网段的主机访问。

USER: 指定能够访问性能数据的用户账户。可以是具体的用户名或通配符。% 表示允许所有用户访问;admin 表示只允许用户名为 admin 的用户访问。

ROLE: 指定能够访问性能数据的用户角色。可以是具体的角色名称或通配符。% 表示允许所有角色访问;monitor 表示只允许具有 monitor 角色的用户访问。

ENABLED: 指示该配置是否启用(YES 或 NO)。如果启用,指定的主机、用户和角色将能够访问性能数据。YES 表示启用访问权限配置;NO 表示禁用访问权限配置。

HISTORY: 指示是否记录历史数据(YES 或 NO)。如果启用,历史性能数据将被记录以供后续分析。YES 表示记录历史数据;NO 表示不记录历史数据。

配置说明

  • HOST状态:%
    • 含义:允许所有主机访问性能数据。这适用于没有特别限制主机访问的场景。如果MySQL 服务器需要允许来自任何主机的访问请求,可以将此字段设置为 %。
  • USER状态:%
    • 含义:允许所有用户访问性能数据。这适用于没有特别限制用户访问的场景。如果所有用户都需要访问性能数据,可以将此字段设置为 %。
  • ROLE状态:%
    • 含义:允许所有角色访问性能数据。这适用于没有特别限制角色访问的场景。如果所有用户角色都需要访问性能数据,可以将此字段设置为 %。
  • ENABLED状态:YES
    • 含义:启用访问控制配置。这意味着上述主机、用户和角色的设置将被应用。当想启用访问控制时,可以将此字段设置为 YES。
  • HISTORY状态:YES
    • 含义:启用历史数据记录。这允许追踪并分析过去的性能数据。当需要保留历史数据以便进行长期分析时,可以将此字段设置为 YES。

查看当前访问控制配置:

SELECT * FROM setup_actors;

允许特定用户和主机访问性能数据:

UPDATE setup_actors SET HOST = '192.168.1.%', USER = 'admin', ROLE = 'monitor', ENABLED = 'YES', HISTORY = 'YES';

禁用历史数据记录:

UPDATE setup_actors SET HISTORY = 'NO' WHERE HOST = '%' AND USER = '%' AND ROLE = '%';

setup_objects 表详解

在 MySQL 的 Performance Schema 中,setup_objects 表用于配置和管理监控对象的类型和状态。该表允许指定不同类型的数据库对象(如事件、函数、过程、表、触发器)是否应该被 Performance Schema 监控,以及是否记录它们的计时信息。通过配置 setup_objects 表中的字段,可以精确控制 Performance Schema 中对数据库对象的监控策略。了解和应用这些配置项可以帮助优化性能数据的收集,并根据需要进行详细的分析和调试。

表结构

mysql> SELECT * FROM setup_objects;
+-------------+--------------------+-------------+---------+-------+
| OBJECT_TYPE | OBJECT_SCHEMA      | OBJECT_NAME | ENABLED | TIMED |
+-------------+--------------------+-------------+---------+-------+
| EVENT       | mysql              | %           | NO      | NO    |
| EVENT       | performance_schema | %           | NO      | NO    |
| EVENT       | information_schema | %           | NO      | NO    |
| EVENT       | %                  | %           | YES     | YES   |
| FUNCTION    | mysql              | %           | NO      | NO    |
| FUNCTION    | performance_schema | %           | NO      | NO    |
| FUNCTION    | information_schema | %           | NO      | NO    |
| FUNCTION    | %                  | %           | YES     | YES   |
| PROCEDURE   | mysql              | %           | NO      | NO    |
| PROCEDURE   | performance_schema | %           | NO      | NO    |
| PROCEDURE   | information_schema | %           | NO      | NO    |
| PROCEDURE   | %                  | %           | YES     | YES   |
| TABLE       | mysql              | %           | NO      | NO    |
| TABLE       | performance_schema | %           | NO      | NO    |
| TABLE       | information_schema | %           | NO      | NO    |
| TABLE       | %                  | %           | YES     | YES   |
| TRIGGER     | mysql              | %           | NO      | NO    |
| TRIGGER     | performance_schema | %           | NO      | NO    |
| TRIGGER     | information_schema | %           | NO      | NO    |
| TRIGGER     | %                  | %           | YES     | YES   |
+-------------+--------------------+-------------+---------+-------+

字段解释

  1. OBJECT_TYPE: 指定要监控的数据库对象类型。常见的类型包括 EVENT(事件)、FUNCTION(函数)、PROCEDURE(过程)、TABLE(表)和 TRIGGER(触发器)。TABLE 表示监控数据库中的表;FUNCTION 表示监控数据库中的函数。
  2. OBJECT_SCHEMA: 指定要监控的对象所在的数据库(模式)。可以是具体的数据库名或通配符。mysql 表示只监控 mysql 数据库中的对象;% 表示监控所有数据库中的对象。
  3. OBJECT_NAME: 指定要监控的对象名称。可以是具体的对象名或通配符。% 表示监控所有名称的对象;users 表示监控名为 users 的对象。
  4. ENABLED: 指示该对象是否启用监控(YES 或 NO)。如果启用,Performance Schema 将监控该对象。YES 表示启用监控;NO 表示禁用监控。
  5. TIMED: 指示是否记录该对象的计时信息(YES 或 NO)。如果启用,Performance Schema 将记录该对象的执行时间。YES 表示记录计时信息;NO 表示不记录计时信息。

配置说明

  • OBJECT_TYPE状态:EVENT, FUNCTION, PROCEDURE, TABLE, TRIGGER
    • 含义:指定监控的对象类型。可以选择要监控的特定类型。如果只关心 TABLE 类型的对象,可以设置 OBJECT_TYPE 为 TABLE。
  • OBJECT_SCHEMA状态:%(表示所有数据库)
    • 含义:指定要监控的数据库。设置为 % 表示所有数据库。如果只对 mysql 数据库中的对象感兴趣,可以将此字段设置为 mysql。
  • OBJECT_NAME状态:%(表示所有对象)
    • 含义:指定要监控的对象名称。设置为 % 表示所有对象。如果只对名为 orders 的表进行监控,可以将此字段设置为 orders。
  • ENABLED状态:YES
    • 含义:启用监控配置。设置为 YES 表示 Performance Schema 将监控指定的对象。如果希望 Performance Schema 监控所有对象,可以将此字段设置为 YES。
  • TIMED状态:YES
    • 含义:记录计时信息。设置为 YES 表示 Performance Schema 将记录对象的执行时间。如果需要详细的执行时间数据,可以将此字段设置为 YES。

查看当前对象监控配置:

SELECT * FROM setup_objects;

启用对所有表的监控并记录计时信息:

UPDATE setup_objects SET ENABLED = 'YES', TIMED = 'YES' WHERE OBJECT_TYPE = 'TABLE';

禁用对特定函数的监控:

UPDATE setup_objects SET ENABLED = 'NO' WHERE OBJECT_TYPE = 'FUNCTION' AND OBJECT_NAME = 'my_function';

threads 表详解

请在此添加图片描述

在 MySQL 的 Performance Schema 中,threads 表用于显示系统中的线程信息。这些线程可以是执行 SQL 查询的线程,也可以是后台进程或内部线程。threads 表提供了有关 MySQL 实例中各个线程的详细信息,包括其 ID、名称、类型、状态和其他相关属性。了解这些信息有助于监控系统的运行情况,诊断性能问题,以及调试和优化

表结构

mysql> SELECT * FROM threads;
+-----------+----------------------------------------+------------+----------------+------------------+------------------+----------------------------+---------------------+------------------+-------------------+-----------------------+------------------+------+--------------+---------+-----------------+--------------+
| THREAD_ID | NAME                                   | TYPE       | PROCESSLIST_ID | PROCESSLIST_USER | PROCESSLIST_HOST | PROCESSLIST_DB             | PROCESSLIST_COMMAND | PROCESSLIST_TIME | PROCESSLIST_STATE | PROCESSLIST_INFO      | PARENT_THREAD_ID | ROLE | INSTRUMENTED | HISTORY | CONNECTION_TYPE | THREAD_OS_ID |
+-----------+----------------------------------------+------------+----------------+------------------+------------------+----------------------------+---------------------+------------------+-------------------+-----------------------+------------------+------+--------------+---------+-----------------+--------------+
|         1 | thread/sql/main                        | BACKGROUND | NULL           | NULL             | NULL             | NULL                       | NULL                |          8319880 | NULL              | NULL                  | NULL             | NULL | YES          | YES     | NULL            |            1 |
|         2 | thread/sql/thread_timer_notifier       | BACKGROUND | NULL           | NULL             | NULL             | NULL                       | NULL                | NULL             | NULL              | NULL                  |                1 | NULL | YES          | YES     | NULL            |           46 |
|         3 | thread/innodb/io_ibuf_thread           | BACKGROUND | NULL           | NULL             | NULL             | NULL                       | NULL                | NULL             | NULL              | NULL                  | NULL             | NULL | YES          | YES     | NULL            |           47 |
|         4 | thread/innodb/io_log_thread            | BACKGROUND | NULL           | NULL             | NULL             | NULL                       | NULL                | NULL             | NULL              | NULL                  | NULL             | NULL | YES          | YES     | NULL            |           48 |
|         5 | thread/innodb/io_read_thread           | BACKGROUND | NULL           | NULL             | NULL             | NULL                       | NULL                | NULL             | NULL              | NULL                  | NULL             | NULL | YES          | YES     | NULL            |           49 |
|         6 | thread/innodb/io_read_thread           | BACKGROUND | NULL           | NULL             | NULL             | NULL                       | NULL                | NULL             | NULL              | NULL                  | NULL             | NULL | YES          | YES     | NULL            |           50 |
|         7 | thread/innodb/io_read_thread           | BACKGROUND | NULL           | NULL             | NULL             | NULL                       | NULL                | NULL             | NULL              | NULL                  | NULL             | NULL | YES          | YES     | NULL            |           51 |
|         8 | thread/innodb/io_read_thread           | BACKGROUND | NULL           | NULL             | NULL             | NULL                       | NULL                | NULL             | NULL              | NULL                  | NULL             | NULL | YES          | YES     | NULL            |           52 |
|         9 | thread/innodb/io_write_thread          | BACKGROUND | NULL           | NULL             | NULL             | NULL                       | NULL                | NULL             | NULL              | NULL                  | NULL             | NULL | YES          | YES     | NULL            |           53 |
+-----------+----------------------------------------+------------+----------------+------------------+------------------+----------------------------+---------------------+------------------+-------------------+-----------------------+------------------+------+--------------+---------+-----------------+--------------+

字段解释

THREAD_ID: 线程的唯一标识符。1 是线程 thread/sql/main 的 ID,2 是线程 thread/sql/thread_timer_notifier 的 ID。

NAME: 线程的名称。可以包括线程的类型和功能。thread/sql/main 代表主要的 SQL 线程,thread/innodb/io_read_thread 代表 InnoDB 的读线程。

TYPE: 线程的类型,通常是 BACKGROUND(后台)或 USER(用户线程)。BACKGROUND 表示后台线程,例如用于系统维护;USER 表示用户创建的线程,例如执行 SQL 查询的线程。

PROCESSLIST_ID: 线程在进程列表中的 ID。如果是后台线程,此字段通常为 NULL。NULL 表示此线程不在进程列表中,例如内部后台线程;8319880 表示特定用户线程的 ID。

PROCESSLIST_USER: 执行该线程的用户。如果线程不是用户线程,则此字段为 NULL。NULL 表示后台线程;root 表示由 root 用户执行的线程。

PROCESSLIST_HOST: 执行该线程的主机名或 IP 地址。如果线程不是用户线程,则此字段为 NULL。NULL 表示后台线程;localhost 表示来自本地主机的连接。

PROCESSLIST_DB: 线程操作的数据库名。如果线程不是用户线程,则此字段为 NULL。NULL 表示后台线程;test_db 表示正在使用的数据库。

PROCESSLIST_COMMAND: 线程正在执行的命令类型,如 Query(查询)、Sleep(休眠)等。NULL 表示后台线程没有当前执行命令;Query 表示正在执行 SQL 查询。

PROCESSLIST_TIME: 线程已执行的时间(秒)。对于后台线程,通常为 NULL。NULL 表示后台线程;120 表示线程已执行了 120 秒的操作。

PROCESSLIST_STATE: 线程当前的状态,例如 Waiting for lock(等待锁定)或 Sending data(发送数据)。NULL 表示后台线程;Sending data 表示线程正在发送数据。

PROCESSLIST_INFO: 线程执行的具体信息,如 SQL 查询语句。后台线程通常没有此信息。NULL 表示后台线程;SELECT * FROM users 表示线程正在执行的 SQL 查询。

PARENT_THREAD_ID: 父线程的 ID。如果该线程没有父线程,则此字段为 NULL。NULL 表示该线程没有父线程;1 表示线程的父线程 ID 是 1。

ROLE: 线程的角色(例如 NULL 表示没有角色信息)。NULL 表示线程没有特别的角色;对于一些特殊的线程,可能会有具体角色信息。

INSTRUMENTED: 指示线程是否被 Performance Schema 监控(YES 或 NO)。YES 表示 Performance Schema 监控该线程;NO 表示不监控。

HISTORY: 指示是否记录线程历史信息(YES 或 NO)。YES 表示记录线程历史信息;NO 表示不记录。

CONNECTION_TYPE: 连接类型,通常为 NULL 表示没有特定类型。NULL 表示没有特定连接类型;在某些情况下可能会有具体的连接类型信息。

THREAD_OS_ID: 操作系统级别的线程 ID。1 表示操作系统中的线程 ID 是 1。

查看所有正在运行的线程:

SELECT * FROM threads;

查找所有 BACKGROUND 类型的线程:

SELECT * FROM threads WHERE TYPE = 'BACKGROUND';

获取特定线程的信息,例如 ID 为 3 的线程:

SELECT * FROM threads WHERE THREAD_ID = 3;

总结

MySQL 的 Performance Schema 提供了非常强大的性能监控工具,而通过合理配置 Performance Schema 的运行时表,可以灵活控制采集数据的范围和深度,避免不必要的性能开销。掌握这些配置表的使用和优化技巧,能够有效提升 MySQL 数据库的运行效率,并帮助开发者和管理员及时定位系统瓶颈。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/884873.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Java-数据结构-Map和Set-(二)-哈希表 |ू・ω・` )

文本目录: ❄️一、哈希表: ☑ 1、概念: ☑ 2、冲突-概念: ☑ 3、冲突-避免: ☞ 1)、避免冲突-哈希函数的设计: ☞ 2)、避免冲突-负载因子调节(重点): ☑ 4、冲突-解决&…

cloud-(Nacos)--注册中心原理-服务注册-服务发现

并且通过(RestTemplate)Http请求实现了跨微服务的远程调用。不过这种手动发送Http请求的方式存在一些问题 在大型微服务项目中,服务提供者的数量会非常多,为了管理这些服务就引入了注册中心的概念。注册中心、服务提供者、服务消费者三者间关系如下: 流程如下: 服务启动…

Mac安装Manim并运行

1.在macOS上创建Python虚拟环境,可以使用venv模块,这是Python自带的库,也可以使用conda。以下是使用venv创建和使用Python虚拟环境的步骤: 打开终端。 创建一个新的目录来存放你的项目,并进入该目录: mk…

15.安卓逆向-frida基础-HOOK类方法1

免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 内容参考于:图灵Python学院 本人写的内容纯属胡编乱造,全都是合成造假,仅仅只是为了娱乐,请不要盲目相信。 工…

WEB服务器——Tomcat

服务器是可以使用java完成编写,是可以接受页面发送的请求和响应数据给前端浏览器的,而在开发中真正用到的Web服务器,我们不会自己写的,都是使用目前比较流行的web服务器。 如:Tomcat 1. 简介 Tomcat 是一个开源的轻量…

【CAM350】使用总结 <二>{ 光绘Gerber 比较 }

一、 比较两份版本不同的光绘文件: //Analysis-Compare layers// 二、参数默认,比较完成给出结果 三、也可以直接在一份文件上选择“Draw on top” 四、对比差距直观可见

家中浮毛太多怎么办?希喂、米家、安德迈更推荐哪款?

在现代养宠家庭生活中,宠物空气净化器已经成为不可或缺的家电之一。 而在众多空气净化器类型中,宠物空气净化器以其独特的设计和卓越的净化效果,逐渐赢得了越来越多养宠家庭的青睐。 它不仅能有效地吸附空中飞舞的浮毛,还能高效…

基于SSM+小程序的在线课堂微信管理系统(在线课堂1)(源码+sql脚本+视频导入教程+文档)

👉文末查看项目功能视频演示获取源码sql脚本视频导入教程视频 1 、功能描述 &emsp1、管理员实现了首页、个人中心、用户管理、课程分类管理、课程信息管理、课程订阅管理、课程视频管理、公告栏管理、留言板管理、系统管理。 2、用户实现了首页、课程信息、公…

此连接非私人连接

当你手机浏览器输入网站打开提示“此连接非私人连接,此网站可能在冒充来窃取你的个人或财务信息。你应回到之前的页面”这是因为该网站的SSL数字证书到期导致,需要此网站的管理员重新申请数字证书替换之前的文件才可以实现。 注意:如果你不是…

实用SQL小总结

WHERE 条件 column 为纯英文字符 或 不包含任何字符 语法: SELECT * FROM your_table WHERE REGEXP(your_column,^[A-Za-z]$); SELECT * FROM your_table WHERE NOT REGEXP(your_column,^[A-Za-z]$);例: SELECT DISTINCT t.pldlibho FROM kibb_pldlyw…

LLM - 使用 vLLM 部署 Qwen2-VL 多模态大模型 (配置 FlashAttention) 教程

欢迎关注我的CSDN:https://spike.blog.csdn.net/ 本文地址:https://spike.blog.csdn.net/article/details/142528967 免责声明:本文来源于个人知识与公开资料,仅用于学术交流,欢迎讨论,不支持转载。 vLLM 用…

02-ZYNQ linux开发环境安装,基于Petalinux2022.2和Vitis2022.2

petalinux安装 Petalinux 工具是 Xilinx 公司推出的嵌入式 Linux 开发套件,包括了 u-boot、Linux Kernel、device-tree、rootfs 等源码和库,以及 Yocto recipes,可以让客户很方便的生成、配置、编译及自定义 Linux 系统。Petalinux 支持 Ver…

uniapp EChars图表

1. uniapp EChars图表 (1)Apache ECharts 一个基于 JavaScript 的开源可视化图表库   https://echarts.apache.org/examples/zh/index.html (1)官网图例 (2)个人实现图例 1.1. 下载echart 1.1.1. 下…

docker - 迁移和备份

文章目录 1、docker commit1.1、查询 容器 docker ps1.2、docker commit zookeeper zookeeper:3.4.13 2、docker save -o2.1、宿主机 切换到 /opt 目录下2.2、将镜像保存到 宿主机/opt目录下 3、docker load -i 对某一个容器修改完毕以后,我们可以把最新的容器部署到…

【文心智能体 | AI大师工坊】如何使用智能体插件,完成一款旅游类智能体的开发,来体验一下我的智能体『​​​​​​​厦门CityWalk』

目录 1.1、智能体运行效果 1.2、创作灵感来源 1.3、如何制作智能体 1.4、可能会遇到的几个问题 1.5、快速调优指南 『厦门CityWalk🚀』我的优质智能体:https://0nxj3k.smartapps.baidu.com/?_swebfr1&_swebScene3621000000000000 在当今这个全…

Bytebase 2.22.3 - 一键回滚 PostgreSQL DML 变更

🚀 新功能 支持一键回滚 PostgreSQL DML 变更。 🎄 改进 优化 DML 事前备份和回滚体验: 引导用户创建 bbdataarchive 数据库。如果没有 bbdataarchive 数据库,无法开启备份功。用户现在可以在创建工单之后开启或关闭备份功能&a…

Python | Leetcode Python题解之第437题路径总和III

题目: 题解: class Solution:def pathSum(self, root: TreeNode, targetSum: int) -> int:prefix collections.defaultdict(int)prefix[0] 1def dfs(root, curr):if not root:return 0ret 0curr root.valret prefix[curr - targetSum]prefix[cu…

ROS学习笔记(四):使用 `ros2 run usb_cam usb_cam_node_exe` 启动 USB 摄像头

文章目录 前言1 安装 usb_cam 包2 启动 USB 摄像头3 订阅相机发布的节点信息并进行可视化3.1 使用 rqt_image_view3.2 使用 image_view3.3 使用 rviz 4 常见问题与解决方案4.1 摄像头未被识别4.2 相机显示异常4.3 如何指定不同的相机4.4 摄像头参数调整 5. 调试信息 5. 结论 前…

9.5K Star,开源在线网盘

Hi,骚年,我是大 G,公众号「GitHub 指北」会推荐 GitHub 上有趣有用的项目,一分钟 get 一个优秀的开源项目,挖掘开源的价值,欢迎关注。 随着云存储的广泛应用,越来越多的人和企业需要一个简单、…

用Promise实现前端并发请求

/** * 构造假请求 */ async function request(url) {return new Promise((resolve) > {setTimeout(() > {resolve(url);},// Math.random() * 500 800,1000,);}); }请求一次,查看耗时,预计应该是1s: async function requestOnce() {c…