mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-31 15:50:51 +03:00 
			
		
		
		
	 899aaa6bb2
			
		
	
	899aaa6bb2
	
	
	
		
			
			Added an option to yassl to allow "quiet shutdown" like openssl does. This option causes the SSL libs to NOT perform the close_notify handshake during shutdown. This fixes a hang we experience because we hold a lock during socket shutdown.
		
			
				
	
	
		
			57 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| # Turn on ssl between the client and server
 | |
| # and run a number of tests
 | |
| 
 | |
| -- source include/have_ssl.inc
 | |
| -- source include/big_test.inc
 | |
| 
 | |
| --disable_warnings
 | |
| DROP TABLE IF EXISTS t1, t2;
 | |
| --enable_warnings
 | |
| 
 | |
| #
 | |
| # Bug #29579 Clients using SSL can hang the server
 | |
| #
 | |
| 
 | |
| connect (ssl_con,localhost,root,,,,,SSL);
 | |
| 
 | |
| create table t1 (a int);
 | |
| 
 | |
| disconnect ssl_con;
 | |
| 
 | |
|   
 | |
| --disable_query_log
 | |
| --disable_result_log
 | |
| 
 | |
| let $count= 2000;
 | |
| while ($count)
 | |
| {
 | |
|   connect (ssl_con,localhost,root,,,,,SSL);
 | |
|   
 | |
|   eval insert into t1 values ($count);
 | |
|   dec $count;
 | |
|   
 | |
|   # This select causes the net buffer to fill as the server sends the results 
 | |
|   # but the client doesn't reap the results. The results are larger each time
 | |
|   # through the loop, so that eventually the buffer is completely full
 | |
|   # at the exact moment the server attempts to the close the connection with
 | |
|   # the lock held.
 | |
|   send select * from t1;
 | |
|   
 | |
|   # now send the quit the command so the server will initiate the shutdown.
 | |
|   send_quit ssl_con; 
 | |
|   
 | |
|   # if the server is hung, this will hang too:
 | |
|   connect (ssl_con2,localhost,root,,,,,SSL);
 | |
|   
 | |
|   # no hang if we get here, close and retry
 | |
|   disconnect ssl_con2;
 | |
|   disconnect ssl_con;
 | |
| }  
 | |
| --enable_query_log
 | |
| --enable_result_log
 | |
| 
 | |
| connect (ssl_con,localhost,root,,,,,SSL);
 | |
| 
 | |
| drop table t1;
 | |
| 
 |