mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-22 15:54:04 +02:00 
			
		
		
		
	 c507678b20
			
		
	
	
	c507678b20
	
	
	
		
			
			- Introduced the variable "innodb_truncate_temporary_tablespace_now" to shrink the temporary tablespace. Steps for shrinking the temporary tablespace: 1) Find the last used extent in temporary tablespace by iterating through the BITMAP in extent descriptor pages 2) If the last used extent is lesser than user specified size then set desired target size to user specified size 3) Store the page contents of "to be modified" extent descriptor pages, latches the "to be modified" extent descriptor pages and check for buffer pool memory availability 4) Update the FSP_SIZE and FSP_FREE_LIMIT in header page 5) Remove the "to be truncated" pages from FSP_FREE and FSP_FREE_FRAG list 6) Reset the bitmap in the last descriptor pages for the "to be truncated" pages. 7) Clear the freed range in temporary tablespace which are to be truncated. 8) Evict the "to be truncated" temporary tablespace pages from LRU list. 9) In case of multiple files, calculate the truncated last file size and do truncation in last file 10) Commit the mini-transaction for shrinking the tablespace
		
			
				
	
	
		
			22 lines
		
	
	
	
		
			1,007 B
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			22 lines
		
	
	
	
		
			1,007 B
		
	
	
	
		
			Text
		
	
	
	
	
	
| --source include/have_innodb.inc
 | |
| --source include/have_sequence.inc
 | |
| --source include/have_debug.inc
 | |
| 
 | |
| call mtr.add_suppression("InnoDB: Cannot shrink the temporary tablespace");
 | |
| --source include/restart_mysqld.inc
 | |
| SET GLOBAL INNODB_LIMIT_OPTIMISTIC_INSERT_DEBUG=2;
 | |
| CREATE TEMPORARY TABLE t1(f1 INT NOT NULL,
 | |
|                           f2 INT NOT NULL)ENGINE=InnoDB;
 | |
| INSERT INTO t1 SELECT seq, seq FROM seq_1_to_65536;
 | |
| DROP TABLE t1;
 | |
| SELECT NAME, FILE_SIZE FROM INFORMATION_SCHEMA.INNODB_SYS_TABLESPACES WHERE SPACE= 4294967294;
 | |
| 
 | |
| SET @saved_debug_dbug = @@SESSION.debug_dbug;
 | |
| SET DEBUG_DBUG="+d,fail_temp_truncate";
 | |
| SET GLOBAL INNODB_TRUNCATE_TEMPORARY_TABLESPACE_NOW= 1;
 | |
| SELECT NAME, FILE_SIZE FROM INFORMATION_SCHEMA.INNODB_SYS_TABLESPACES WHERE SPACE= 4294967294;
 | |
| SET DEBUG_DBUG=@saved_debug_dbug;
 | |
| 
 | |
| SET GLOBAL INNODB_TRUNCATE_TEMPORARY_TABLESPACE_NOW= 1;
 | |
| SELECT NAME, FILE_SIZE FROM INFORMATION_SCHEMA.INNODB_SYS_TABLESPACES WHERE SPACE= 4294967294;
 | |
| SET GLOBAL INNODB_LIMIT_OPTIMISTIC_INSERT_DEBUG=default;
 |