mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-26 16:38:11 +01:00 
			
		
		
		
	 775cba4d0f
			
		
	
	
	775cba4d0f
	
	
	
		
			
			- FLUSH GLOBAL STATUS now resets most global_status_vars.
  At this stage, this is mainly to be used for testing.
- FLUSH SESSION STATUS added as an alias for FLUSH STATUS.
- FLUSH STATUS does not require any privilege (before required RELOAD).
- FLUSH GLOBAL STATUS requires RELOAD privilege.
- All global status reset moved to FLUSH GLOBAL STATUS.
- Replication semisync status variables are now reset by
  FLUSH GLOBAL STATUS.
- In test cases, the only changes are:
  - Replace FLUSH STATUS with FLUSH GLOBAL STATUS
  - Replace FLUSH STATUS with FLUSH STATUS; FLUSH GLOBAL STATUS.
    This was only done in a few tests where the test was using SHOW STATUS
    for both local and global variables.
- Uptime_since_flush_status is now always provided, independent if
  ENABLED_PROFILING is enabled when compiling MariaDB.
- @@global.Uptime_since_flush_status is reset on FLUSH GLOBAL STATUS
  and @@session.Uptime_since_flush_status is reset on FLUSH SESSION STATUS.
- When connected, @@session.Uptime_since_flush_status is set to 0.
		
	
			
		
			
				
	
	
		
			273 lines
		
	
	
	
		
			9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			273 lines
		
	
	
	
		
			9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| # Tests for the performance schema
 | |
| 
 | |
| # =============
 | |
| # DOCUMENTATION
 | |
| # =============
 | |
| 
 | |
| # Verify how table io is aggregated into various tables
 | |
| #
 | |
| # In the instance dimension:
 | |
| # - table_io_waits_summary_by_index_usage
 | |
| # - table_io_waits_summary_by_table
 | |
| # - table_lock_waits_summary_by_table
 | |
| # - objects_summary_global_by_type
 | |
| #
 | |
| # In the thread dimension:
 | |
| # - events_waits_summary_by_thread_by_event_name
 | |
| # - events_waits_summary_by_account_by_event_name
 | |
| # - events_waits_summary_by_user_by_event_name
 | |
| # - events_waits_summary_by_host_by_event_name
 | |
| #
 | |
| # Globally:
 | |
| # - events_waits_summary_global_by_event_name
 | |
| #
 | |
| # The tests are written with the following helpers:
 | |
| # - include/table_aggregate_setup.inc
 | |
| # - include/table_aggregate_load.inc
 | |
| # - include/table_aggregate_cleanup.inc
 | |
| #
 | |
| # Helpers are intended to be used as follows.
 | |
| #
 | |
| # A Typical test t/table_aggregate_xxx.test will consist of:
 | |
| # --source ../include/table_aggregate_setup.inc
 | |
| # 
 | |
| # ... statements to modify the default configuration ...
 | |
| #
 | |
| # --source ../include/table_aggregate_load.inc
 | |
| # --source ../include/table_aggregate_cleanup.inc
 | |
| #
 | |
| # Naming conventions for t/table_aggregate_xxx.test are as follows:
 | |
| # t/<instrument>aggregate_<mode><actors><objects>
 | |
| #
 | |
| # <instrument> corresponds to different instruments settings
 | |
| # - table: both table io and table lock are instrumented
 | |
| # - table_io: only table io is instrumented
 | |
| # - table_lock: only table lock is instrumented
 | |
| #
 | |
| # <mode> corresponds to different consumers settings
 | |
| # - off: global_instrumentation OFF
 | |
| # - global: global_instrumentation ON, thread_instrumentation OFF
 | |
| # - thread: global_instrumentation ON, thread_instrumentation ON,
 | |
| #           events_* consumers OFF
 | |
| # - history: global_instrumentation ON, thread_instrumentation ON,
 | |
| #           events_* consumers ON
 | |
| #
 | |
| # <actors> corresponds to different setup_actors settings
 | |
| # - 4u: every test user (user1, user2, user3, user4) is ON
 | |
| # - 2u: (user1, user3) are ON, (user2, user4) are OFF
 | |
| #
 | |
| # <objects> corresponds to different setup_objects settings
 | |
| # - 3t: tables t1, t2 and t3 are ON
 | |
| # - 2t: tables t1 and t3 are ON, table t2 is OFF
 | |
| #
 | |
| 
 | |
| # ========================================
 | |
| # HELPER include/table_aggregate_setup.inc
 | |
| # ========================================
 | |
| 
 | |
| --source include/not_embedded.inc
 | |
| --source include/have_perfschema.inc
 | |
| --source include/no_protocol.inc
 | |
| --source ../include/wait_for_pfs_thread_count.inc
 | |
| 
 | |
| --disable_query_log
 | |
| create user user1@localhost;
 | |
| grant ALL on *.* to user1@localhost;
 | |
| create user user2@localhost;
 | |
| grant ALL on *.* to user2@localhost;
 | |
| create user user3@localhost;
 | |
| grant ALL on *.* to user3@localhost;
 | |
| create user user4@localhost;
 | |
| grant ALL on *.* to user4@localhost;
 | |
| 
 | |
| flush privileges;
 | |
| 
 | |
| # Purge old users, hosts, user/host from previous tests
 | |
| truncate table performance_schema.accounts;
 | |
| truncate table performance_schema.users;
 | |
| truncate table performance_schema.hosts;
 | |
| 
 | |
| # Save the setup
 | |
| 
 | |
| --disable_warnings
 | |
| drop table if exists test.setup_actors;
 | |
| drop table if exists test.setup_objects;
 | |
| --enable_warnings
 | |
| 
 | |
| create table test.setup_actors as
 | |
|   select * from performance_schema.setup_actors;
 | |
| 
 | |
| create table test.setup_objects as
 | |
|   select * from performance_schema.setup_objects;
 | |
| 
 | |
| # Only instrument the user connections (by default)
 | |
| truncate table performance_schema.setup_actors;
 | |
| insert into performance_schema.setup_actors
 | |
|   set host= 'localhost', user= 'user1', role= '%';
 | |
| insert into performance_schema.setup_actors
 | |
|   set host= 'localhost', user= 'user2', role= '%';
 | |
| insert into performance_schema.setup_actors
 | |
|   set host= 'localhost', user= 'user3', role= '%';
 | |
| insert into performance_schema.setup_actors
 | |
|   set host= 'localhost', user= 'user4', role= '%';
 | |
| 
 | |
| # Only instrument test.t% tables (by default)
 | |
| truncate table performance_schema.setup_objects;
 | |
| insert into performance_schema.setup_objects
 | |
|   set object_type='TABLE', object_schema='test', object_name='t1', timed='YES';
 | |
| insert into performance_schema.setup_objects
 | |
|   set object_type='TABLE', object_schema='test', object_name='t2', timed='NO';
 | |
| insert into performance_schema.setup_objects
 | |
|   set object_type='TABLE', object_schema='test', object_name='t3', timed='NO';
 | |
| 
 | |
| update performance_schema.threads set instrumented='NO';
 | |
| 
 | |
| # Only instrument table io and lock (by default)
 | |
| update performance_schema.setup_instruments set enabled='NO', timed='NO';
 | |
| update performance_schema.setup_instruments set enabled='YES', timed='YES'
 | |
|   where name in ('wait/io/table/sql/handler',
 | |
|                  'wait/lock/table/sql/handler');
 | |
| 
 | |
| # Enable all consumers (by default)
 | |
| update performance_schema.setup_consumers set enabled='YES';
 | |
| 
 | |
| # Start from a known clean state, to avoid noise from previous tests
 | |
| flush tables;
 | |
| flush global status;
 | |
| 
 | |
| create table test.t1(a int, b int, c int, d int default 0,
 | |
|   primary key(a),
 | |
|   index index_b(b),
 | |
|   index index_cb(c, b));
 | |
| create table test.t2 like test.t1;
 | |
| create table test.t3 like test.t1;
 | |
| 
 | |
| #
 | |
| # Note:
 | |
| # For test robustness and to avoid picking up noise from other tests scripts,
 | |
| # it is better to use:
 | |
| #   in ('t1', 't2', 't3)
 | |
| # explicitly instead of:
 | |
| #   like 't%'
 | |
| 
 | |
| --disable_warnings
 | |
| drop procedure if exists dump_thread;
 | |
| drop procedure if exists dump_one_thread;
 | |
| --enable_warnings
 | |
| 
 | |
| delimiter $$;
 | |
| 
 | |
| create procedure dump_thread()
 | |
| begin
 | |
|   call dump_one_thread('user1');
 | |
|   call dump_one_thread('user2');
 | |
|   call dump_one_thread('user3');
 | |
|   call dump_one_thread('user4');
 | |
| end
 | |
| $$
 | |
| 
 | |
| create procedure dump_one_thread(in username varchar(64))
 | |
| begin
 | |
|   declare my_thread_id int;
 | |
| 
 | |
|   set my_thread_id = (select thread_id from performance_schema.threads
 | |
|                         where processlist_user=username);
 | |
| 
 | |
|   if (my_thread_id is not null) then
 | |
|     select username, event_name, count_star
 | |
|       from performance_schema.events_waits_summary_by_thread_by_event_name
 | |
|       where event_name in
 | |
|       ('wait/io/table/sql/handler',
 | |
|        'wait/lock/table/sql/handler')
 | |
|       and thread_id = my_thread_id
 | |
|       order by event_name;
 | |
|   else
 | |
|     select username, "not found" as status;
 | |
|   end if;
 | |
| end
 | |
| $$
 | |
| 
 | |
| delimiter ;$$
 | |
| 
 | |
| prepare dump_waits_user from
 | |
|   "select user, event_name, count_star
 | |
|   from performance_schema.events_waits_summary_by_user_by_event_name
 | |
|   where user like \'user%\' and event_name in
 | |
|   (\'wait/io/table/sql/handler\',
 | |
|    \'wait/lock/table/sql/handler\')
 | |
|   order by user, event_name;";
 | |
| 
 | |
| prepare dump_waits_account from
 | |
|   "select user, host, event_name, count_star
 | |
|   from performance_schema.events_waits_summary_by_account_by_event_name
 | |
|   where user like \'user%\' and event_name in
 | |
|   (\'wait/io/table/sql/handler\',
 | |
|    \'wait/lock/table/sql/handler\')
 | |
|   order by user, host, event_name;";
 | |
| 
 | |
| prepare dump_waits_host from
 | |
|   "select host, event_name, count_star
 | |
|   from performance_schema.events_waits_summary_by_host_by_event_name
 | |
|   where host=\'localhost\'  and event_name in
 | |
|   (\'wait/io/table/sql/handler\',
 | |
|    \'wait/lock/table/sql/handler\')
 | |
|   order by host, event_name;";
 | |
| 
 | |
| prepare dump_waits_global from
 | |
|   "select event_name, count_star
 | |
|   from performance_schema.events_waits_summary_global_by_event_name
 | |
|   where event_name in
 | |
|   (\'wait/io/table/sql/handler\',
 | |
|    \'wait/lock/table/sql/handler\')
 | |
|   order by event_name;";
 | |
| 
 | |
| prepare dump_waits_history from
 | |
|   "select event_name,
 | |
|     sum(if(number_of_bytes is null, 1, number_of_bytes)) as 'count(event_name)',
 | |
|     object_type, object_schema, object_name
 | |
|   from performance_schema.events_waits_history_long
 | |
|   where event_name in
 | |
|   (\'wait/io/table/sql/handler\',
 | |
|    \'wait/lock/table/sql/handler\')
 | |
|   group by object_type, object_schema, object_name, event_name
 | |
|   order by object_type, object_schema, object_name, event_name;";
 | |
| 
 | |
| prepare dump_waits_index_io from
 | |
|   "select object_type, object_schema, object_name, index_name,
 | |
|   count_star, count_read, count_write,
 | |
|   count_fetch, count_insert, count_update, count_delete
 | |
|   from performance_schema.table_io_waits_summary_by_index_usage
 | |
|   where object_type='TABLE' and object_schema='test'
 | |
|   and object_name in ('t1', 't2', 't3')
 | |
|   order by object_type, object_schema, object_name, index_name;";
 | |
| 
 | |
| prepare dump_waits_table_io from
 | |
|   "select object_type, object_schema, object_name,
 | |
|   count_star, count_read, count_write,
 | |
|   count_fetch, count_insert, count_update, count_delete
 | |
|   from performance_schema.table_io_waits_summary_by_table
 | |
|   where object_type='TABLE' and object_schema='test'
 | |
|   and object_name in ('t1', 't2', 't3')
 | |
|   order by object_type, object_schema, object_name";
 | |
| 
 | |
| prepare dump_waits_table_lock from
 | |
|   "select object_type, object_schema, object_name,
 | |
|   count_star, count_read, count_write,
 | |
|   count_read_normal, count_read_with_shared_locks,
 | |
|   count_read_high_priority, count_read_no_insert,
 | |
|   count_read_external,
 | |
|   count_write_low_priority,
 | |
|   count_write_external
 | |
|   from performance_schema.table_lock_waits_summary_by_table
 | |
|   where object_type='TABLE' and object_schema='test'
 | |
|   and object_name in ('t1', 't2', 't3')
 | |
|   order by object_type, object_schema, object_name";
 | |
| 
 | |
| prepare dump_objects_summary from
 | |
|   "select object_type, object_schema, object_name, count_star 
 | |
|   from performance_schema.objects_summary_global_by_type
 | |
|   where object_type='TABLE' and object_schema='test'
 | |
|   and object_name in ('t1', 't2', 't3')
 | |
|   order by object_type, object_schema, object_name";
 | |
| 
 | |
| --enable_query_log
 |