mirror of
https://github.com/MariaDB/server.git
synced 2025-07-24 19:42:23 +03:00
This was done to get more information about where time is spent. Now we can get proper timing for time spent in commit, rollback, binlog write etc. Following stages was added: - Commit - Commit_implicit - Rollback - Rollback implicit - Binlog write - Init for update - This is used instead of "Init" for insert, update and delete. - Staring cleanup Following stages where changed: - "Unlocking tables" stage reset stage to previous stage at end - "binlog write" stage resets stage to previous stage at end - "end" -> "end of update loop" - "cleaning up" -> "Reset for next command" - Added stage_searching_rows_for_update when searching for rows to be deleted. Other things: - Renamed all stages to start with big letter (before there was no consitency) - Increased performance_schema_max_stage_classes from 150 to 160. - Most of the test changes in performance schema comes from renaming of stages. - Removed duplicate output of variables and inital state in a lot of performance schema tests. This was done to make it easier to change a default value for a performance variable without affecting all tests. - Added start_server_variables.test to check configuration - Removed some duplicate "closing tables" stages - Updated position for "stage_init_update" and "stage_updating" for delete, insert and update to be just before update loop (for more exact timing). - Don't set "Checking permissions" twice in a row. - Remove stage_end stage from creating views (not done for create table either). - Updated default performance history size from 10 to 20 because of new stages - Ensure that ps_enabled is correct (to be used in a later patch)
64 lines
1.9 KiB
Plaintext
64 lines
1.9 KiB
Plaintext
#
|
|
# Verify that the configuration file defaults were processed correctly
|
|
#
|
|
SELECT * FROM performance_schema.setup_instruments
|
|
WHERE name IN (
|
|
'wait/synch/mutex/sql/LOCK_user_conn',
|
|
'wait/synch/mutex/sql/LOCK_uuid_generator',
|
|
'wait/synch/mutex/sql/LOCK_plugin',
|
|
'stage/sql/creating table')
|
|
AND enabled = 'yes' AND timed = 'no'
|
|
ORDER BY name;
|
|
NAME ENABLED TIMED
|
|
stage/sql/Creating table YES NO
|
|
wait/synch/mutex/sql/LOCK_plugin YES NO
|
|
wait/synch/mutex/sql/LOCK_user_conn YES NO
|
|
SELECT * FROM performance_schema.setup_instruments
|
|
WHERE name = 'wait/synch/mutex/sql/LOCK_thread_count'
|
|
AND enabled = 'no' AND timed = 'no';
|
|
NAME ENABLED TIMED
|
|
wait/synch/mutex/sql/LOCK_thread_count NO NO
|
|
SELECT * FROM performance_schema.setup_instruments
|
|
WHERE name IN (
|
|
'wait/synch/mutex/sql/LOG_INFO::lock',
|
|
'wait/synch/mutex/sql/THD::LOCK_thd_data')
|
|
AND enabled = 'yes' AND timed = 'yes'
|
|
ORDER BY name;
|
|
NAME ENABLED TIMED
|
|
wait/synch/mutex/sql/LOG_INFO::lock YES YES
|
|
wait/synch/mutex/sql/THD::LOCK_thd_data YES YES
|
|
SELECT * FROM performance_schema.setup_instruments
|
|
WHERE name = 'wait/synch/mutex/sql/hash_filo::lock'
|
|
AND enabled = 'no' AND timed = 'no'
|
|
ORDER BY name;
|
|
NAME ENABLED TIMED
|
|
wait/synch/mutex/sql/hash_filo::lock NO NO
|
|
#
|
|
# Verify that the instrument startup settings are not not visible.
|
|
#
|
|
SHOW VARIABLES LIKE "%/wait/synch/mutex%";
|
|
Variable_name Value
|
|
#
|
|
# Verify command line options are processed correctly
|
|
#
|
|
#
|
|
# Verify that wait/io/table/sql/handler is enabled and timed
|
|
#
|
|
SELECT * FROM performance_schema.setup_instruments
|
|
WHERE name like "%wait/io/table/sql/handler%";
|
|
NAME ENABLED TIMED
|
|
wait/io/table/sql/handler YES YES
|
|
#
|
|
# Stop server
|
|
# Restart server with wait/io/table/sql/handler disabled
|
|
# Enable reconnect
|
|
# Wait until connected again
|
|
# Disable reconnect
|
|
#
|
|
# Verify that wait/io/table is disabled
|
|
#
|
|
SELECT * FROM performance_schema.setup_instruments
|
|
WHERE name like "%wait/io/table/sql/handler%";
|
|
NAME ENABLED TIMED
|
|
wait/io/table/sql/handler NO NO
|