mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Fix base backup rate limiting in presence of slow i/o
When source i/o on disk was too slow compared to the rate limiting specified, the system could end up with a negative value for sleep that it never got out of, which caused rate limiting to effectively be turned off. Discussion: https://postgr.es/m/CABUevEy_-e0YvL4ayoX8bH_Ja9w%2BBHoP6jUgdxZuG2nEj3uAfQ%40mail.gmail.com Analysis by me, patch by Antonin Houska
This commit is contained in:
		| @@ -1308,26 +1308,16 @@ throttle(size_t increment) | |||||||
| 							 WL_LATCH_SET | WL_TIMEOUT | WL_POSTMASTER_DEATH, | 							 WL_LATCH_SET | WL_TIMEOUT | WL_POSTMASTER_DEATH, | ||||||
| 								(long) (sleep / 1000)); | 								(long) (sleep / 1000)); | ||||||
| 	} | 	} | ||||||
| 	else |  | ||||||
| 	{ |  | ||||||
| 		/* |  | ||||||
| 		 * The actual transfer rate is below the limit.  A negative value |  | ||||||
| 		 * would distort the adjustment of throttled_last. |  | ||||||
| 		 */ |  | ||||||
| 		wait_result = 0; |  | ||||||
| 		sleep = 0; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	/* | 	/* | ||||||
| 	 * Only a whole multiple of throttling_sample was processed. The rest will | 	 * As we work with integers, only whole multiple of throttling_sample was | ||||||
| 	 * be done during the next call of this function. | 	 * processed. The rest will be done during the next call of this function. | ||||||
| 	 */ | 	 */ | ||||||
| 	throttling_counter %= throttling_sample; | 	throttling_counter %= throttling_sample; | ||||||
|  |  | ||||||
| 	/* Once the (possible) sleep has ended, new period starts. */ | 	/* | ||||||
| 	if (wait_result & WL_TIMEOUT) | 	 * Time interval for the remaining amount and possible next increments | ||||||
| 		throttled_last += elapsed + sleep; | 	 * starts now. | ||||||
| 	else if (sleep > 0) | 	 */ | ||||||
| 		/* Sleep was necessary but might have been interrupted. */ |  | ||||||
| 	throttled_last = GetCurrentIntegerTimestamp(); | 	throttled_last = GetCurrentIntegerTimestamp(); | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user