The Performance Schema maintains tables for collecting current and recent wait events, and aggregates that information in summary tables. Section 29.12.4, “Performance Schema Wait Event Tables” describes the events on which wait summaries are based. See that discussion for information about the content of wait events, the current and recent wait event tables, and how to control wait event collection, which is disabled by default.
Example wait event summary information:
mysql> SELECT *
FROM performance_schema.events_waits_summary_global_by_event_name\G
...
*************************** 6. row ***************************
EVENT_NAME: wait/synch/mutex/sql/BINARY_LOG::LOCK_index
COUNT_STAR: 8
SUM_TIMER_WAIT: 2119302
MIN_TIMER_WAIT: 196092
AVG_TIMER_WAIT: 264912
MAX_TIMER_WAIT: 569421
...
*************************** 9. row ***************************
EVENT_NAME: wait/synch/mutex/sql/hash_filo::lock
COUNT_STAR: 69
SUM_TIMER_WAIT: 16848828
MIN_TIMER_WAIT: 0
AVG_TIMER_WAIT: 244185
MAX_TIMER_WAIT: 735345
...
Each wait event summary table has one or more grouping columns
to indicate how the table aggregates events. Event names refer
to names of event instruments in the
setup_instruments table:
events_waits_summary_by_account_by_event_namehasEVENT_NAME,USER, andHOSTcolumns. Each row summarizes events for a given account (user and host combination) and event name.events_waits_summary_by_host_by_event_namehasEVENT_NAMEandHOSTcolumns. Each row summarizes events for a given host and event name.events_waits_summary_by_instancehasEVENT_NAMEandOBJECT_INSTANCE_BEGINcolumns. Each row summarizes events for a given event name and object. If an instrument is used to create multiple instances, each instance has a uniqueOBJECT_INSTANCE_BEGINvalue and is summarized separately in this table.events_waits_summary_by_thread_by_event_namehasTHREAD_IDandEVENT_NAMEcolumns. Each row summarizes events for a given thread and event name.events_waits_summary_by_user_by_event_namehasEVENT_NAMEandUSERcolumns. Each row summarizes events for a given user and event name.events_waits_summary_global_by_event_namehas anEVENT_NAMEcolumn. Each row summarizes events for a given event name. An instrument might be used to create multiple instances of the instrumented object. For example, if there is an instrument for a mutex that is created for each connection, there are as many instances as there are connections. The summary row for the instrument summarizes over all these instances.
Each wait event summary table has these summary columns containing aggregated values:
COUNT_STARThe number of summarized events. This value includes all events, whether timed or nontimed.
SUM_TIMER_WAITThe total wait time of the summarized timed events. This value is calculated only for timed events because nontimed events have a wait time of
NULL. The same is true for the othervalues.xxx_TIMER_WAITMIN_TIMER_WAITThe minimum wait time of the summarized timed events.
AVG_TIMER_WAITThe average wait time of the summarized timed events.
MAX_TIMER_WAITThe maximum wait time of the summarized timed events.
The wait event summary tables have these indexes:
events_waits_summary_by_account_by_event_name:Primary key on (
USER,HOST,EVENT_NAME)
events_waits_summary_by_host_by_event_name:Primary key on (
HOST,EVENT_NAME)
events_waits_summary_by_instance:Primary key on (
OBJECT_INSTANCE_BEGIN)Index on (
EVENT_NAME)
events_waits_summary_by_thread_by_event_name:Primary key on (
THREAD_ID,EVENT_NAME)
events_waits_summary_by_user_by_event_name:Primary key on (
USER,EVENT_NAME)
events_waits_summary_global_by_event_name:Primary key on (
EVENT_NAME)
TRUNCATE TABLE is permitted for
wait summary tables. It has these effects:
For summary tables not aggregated by account, host, or user, truncation resets the summary columns to zero rather than removing rows.
For summary tables aggregated by account, host, or user, truncation removes rows for accounts, hosts, or users with no connections, and resets the summary columns to zero for the remaining rows.
In addition, each wait summary table that is aggregated by
account, host, user, or thread is implicitly truncated by
truncation of the connection table on which it depends, or
truncation of
events_waits_summary_global_by_event_name.
For details, see
Section 29.12.8, “Performance Schema Connection Tables”.