mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Remove the "snapshot too old" feature.
Remove the old_snapshot_threshold setting and mechanism for producing
the error "snapshot too old", originally added by commit 848ef42b.
Unfortunately it had a number of known problems in terms of correctness
and performance, mostly reported by Andres in the course of his work on
snapshot scalability.  We agreed to remove it, after a long period
without an active plan to fix it.
This is certainly a desirable feature, and someone might propose a new
or improved implementation in the future.
Reported-by: Andres Freund <andres@anarazel.de>
Discussion: https://postgr.es/m/CACG%3DezYV%2BEvO135fLRdVn-ZusfVsTY6cH1OZqWtezuEYH6ciQA%40mail.gmail.com
Discussion: https://postgr.es/m/20200401064008.qob7bfnnbu4w5cw4%40alap3.anarazel.de
Discussion: https://postgr.es/m/CA%2BTgmoY%3Daqf0zjTD%2B3dUWYkgMiNDegDLFjo%2B6ze%3DWtpik%2B3XqA%40mail.gmail.com
			
			
This commit is contained in:
		| @@ -5575,20 +5575,3 @@ IssuePendingWritebacks(WritebackContext *wb_context, IOContext io_context) | ||||
|  | ||||
| 	wb_context->nr_pending = 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* | ||||
|  * Implement slower/larger portions of TestForOldSnapshot | ||||
|  * | ||||
|  * Smaller/faster portions are put inline, but the entire set of logic is too | ||||
|  * big for that. | ||||
|  */ | ||||
| void | ||||
| TestForOldSnapshot_impl(Snapshot snapshot, Relation relation) | ||||
| { | ||||
| 	if (RelationAllowsEarlyPruning(relation) | ||||
| 		&& (snapshot)->whenTaken < GetOldSnapshotThresholdTimestamp()) | ||||
| 		ereport(ERROR, | ||||
| 				(errcode(ERRCODE_SNAPSHOT_TOO_OLD), | ||||
| 				 errmsg("snapshot too old"))); | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user