mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-26 08:28:13 +01:00 
			
		
		
		
	 46c3e7e353
			
		
	
	
	46c3e7e353
	
	
	
		
			
			Problem: ======= There are two issues that are addressed in this patch: 1) SHOW BINARY LOGS uses caching to store the binary logs that exist in the log directory; however, if new events are written to the logs, the caching strategy is unaware. This is okay for users, as it is okay for SHOW to return slightly old data. The test, however, can result in inconsistent data. It runs two connections concurrently, where one shows the logs, and the other adds a new file. The output of SHOW BINARY LOGS then depends on when the cache is built, with respect to the time that the second connection rotates the logs. 2) There is a race condition between RESET MASTER and SHOW BINARY LOGS. More specifically, where they both need the binary log lock to begin, SHOW BINARY LOGS only needs the lock to build its cache. If RESET MASTER is issued after SHOW BINARY LOGS has built its cache and before it has returned the results, the presented data may be incorrect. Solution: ======== 1) As it is okay for users to see stale data, to make the test consistent, use DEBUG_SYNC to force the race condition (problem 2) to make SHOW BINARY LOGS build a cache before RESET MASTER is called. Then, use additional logic from the next part of the solution to rebuild the cache. 2) Use an Atomic_counter to keep track of the number of times RESET MASTER has been called. If the value of the counter changes after building the cache, the cache should be rebuilt and the analysis should be restarted. Reviewed By: ============ Andrei Elkin: <andrei.elkin@mariadb.com>
		
			
				
	
	
		
			17 lines
		
	
	
	
		
			449 B
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			17 lines
		
	
	
	
		
			449 B
		
	
	
	
		
			Text
		
	
	
	
	
	
| connect con1,localhost,root,,;
 | |
| FLUSH LOGS;
 | |
| FLUSH LOGS;
 | |
| FLUSH LOGS;
 | |
| SET DEBUG_SYNC= "at_after_lock_index SIGNAL con1_ready WAIT_FOR con1_go";
 | |
| SHOW BINARY LOGS;
 | |
| connect con2,localhost,root,,;
 | |
| SET DEBUG_SYNC= "now WAIT_FOR con1_ready";
 | |
| RESET MASTER;
 | |
| FLUSH LOGS;
 | |
| SET DEBUG_SYNC= "now SIGNAL con1_go";
 | |
| connection con1;
 | |
| # The correct result must consists of two records
 | |
| Log_name	File_size
 | |
| master-bin.000001	#
 | |
| master-bin.000002	#
 | |
| SET debug_sync = 'reset';
 |