mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Use the new "Slab" context for some allocations in reorderbuffer.h.
Note that this change alone does not yet fully address the performance problems triggering this work, a large portion of the slowdown is triggered by the tuple allocator, which isn't converted to the new allocator. It would be possible to do so, but using evenly sized objects, like both the current implementation in reorderbuffer.c and slab.c, wastes a fair amount of memory. A later patch by Tomas will introduce a better approach. Author: Tomas Vondra Reviewed-By: Andres Freund Discussion: https://postgr.es/m/d15dff83-0b37-28ed-0809-95a5cc7292ad@2ndquadrant.com
This commit is contained in:
		| @@ -330,6 +330,12 @@ struct ReorderBuffer | ||||
| 	 */ | ||||
| 	MemoryContext context; | ||||
|  | ||||
| 	/* | ||||
| 	 * Memory contexts for specific types objects | ||||
| 	 */ | ||||
| 	MemoryContext change_context; | ||||
| 	MemoryContext txn_context; | ||||
|  | ||||
| 	/* | ||||
| 	 * Data structure slab cache. | ||||
| 	 * | ||||
| @@ -340,14 +346,6 @@ struct ReorderBuffer | ||||
| 	 * on top of reorderbuffer.c | ||||
| 	 */ | ||||
|  | ||||
| 	/* cached ReorderBufferTXNs */ | ||||
| 	dlist_head	cached_transactions; | ||||
| 	Size		nr_cached_transactions; | ||||
|  | ||||
| 	/* cached ReorderBufferChanges */ | ||||
| 	dlist_head	cached_changes; | ||||
| 	Size		nr_cached_changes; | ||||
|  | ||||
| 	/* cached ReorderBufferTupleBufs */ | ||||
| 	slist_head	cached_tuplebufs; | ||||
| 	Size		nr_cached_tuplebufs; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user