mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-27 00:12:01 +03:00 
			
		
		
		
	Make the visibility map crash-safe.
This involves two main changes from the previous behavior. First, when we set a bit in the visibility map, emit a new WAL record of type XLOG_HEAP2_VISIBLE. Replay sets the page-level PD_ALL_VISIBLE bit and the visibility map bit. Second, when inserting, updating, or deleting a tuple, we can no longer get away with clearing the visibility map bit after releasing the lock on the corresponding heap page, because an intervening crash might leave the visibility map bit set and the page-level bit clear. Making this work requires a bit of interface refactoring. In passing, a few minor but related cleanups: change the test in visibilitymap_set and visibilitymap_clear to throw an error if the wrong page (or no page) is pinned, rather than silently doing nothing; this case should never occur. Also, remove duplicate definitions of InvalidXLogRecPtr. Patch by me, review by Noah Misch.
This commit is contained in:
		| @@ -38,6 +38,7 @@ extern void RelationPutHeapTuple(Relation relation, Buffer buffer, | ||||
| 					 HeapTuple tuple); | ||||
| extern Buffer RelationGetBufferForTuple(Relation relation, Size len, | ||||
| 						  Buffer otherBuffer, int options, | ||||
| 						  struct BulkInsertStateData * bistate); | ||||
| 						  struct BulkInsertStateData * bistate, | ||||
| 						  Buffer *vmbuffer); | ||||
|  | ||||
| #endif   /* HIO_H */ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user