mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-21 08:47:42 +03:00 
			
		
		
		
	 7b1a94ef78
			
		
	
	7b1a94ef78
	
	
	
		
			
			tables' lock." Execution of ALTER TABLE ... ENABLE KEYS on a table (which can take rather long time) prevented concurrent execution of all statements using tables. The problem was caused by the fact that we were holding LOCK_open mutex during whole duration of this statement and particularly during call to handler::enable_indexes(). This behavior was introduced as part of the fix for bug 14262 "SP: DROP PROCEDURE|VIEW (maybe more) write to binlog too late (race cond)" The patch simply restores old behavior. Note that we can safely do this as this operation takes exclusive lock (similar to name-lock) which blocks both DML and DDL on the table being altered. It also introduces mysql-test/include/wait_show_pattern.inc helper script which is used to make test-case for this bug robust enough.
		
			
				
	
	
		
			52 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| # include/wait_show_pattern.inc
 | |
| #
 | |
| # SUMMARY
 | |
| #
 | |
| #   Waits until output produced by SHOW statement which particular type is
 | |
| #   specified as parameter matches certain pattern or maximum time reached.
 | |
| #
 | |
| # NOTES
 | |
| #
 | |
| #   Only the first row produced by the parameter statement is checked.
 | |
| #
 | |
| # USAGE
 | |
| #
 | |
| #   let $show_type= <Tail of SHOW statement>;
 | |
| #   let $show_pattern= 'Pattern to be used for LIKE matching';
 | |
| #   --source wait_show_pattern.inc
 | |
| #
 | |
| # EXAMPLES
 | |
| # 
 | |
| #   alter_table-big.test, wait_slave_status.inc
 | |
| #
 | |
| # SEE ALSO
 | |
| #
 | |
| #   wait_slave_status.inc, wait_condition.inc (>=5.1)
 | |
| #
 | |
| ###############################################################################
 | |
| 
 | |
| --disable_query_log
 | |
| 
 | |
| # We accept to wait maximum 30 seconds (0.2 sec/loop).
 | |
| let $wait_counter= 150;
 | |
| while ($wait_counter)
 | |
| {
 | |
|   let $result= `SHOW $show_type`;
 | |
|   let $success= `SELECT '$result' LIKE $show_pattern`;
 | |
|   if ($success)
 | |
|   {
 | |
|     let $wait_counter= 0;
 | |
|   }
 | |
|   if (!$success)
 | |
|   {
 | |
|     real_sleep 0.2;
 | |
|     dec $wait_counter;
 | |
|   }
 | |
| }
 | |
| if (!$success)
 | |
| {
 | |
|   echo Timeout in wait_show_pattern.inc \$show_type= $show_type \$show_pattern= $show_pattern (\$result= '$result');
 | |
| }
 | |
| 
 | |
| --enable_query_log
 |