On 1/12/18 23:19, Tomas Vondra wrote: > Wouldn't the 'toplevel_by_lsn' be suitable for this? Subtransactions > don't really commit independently, but as part of the toplevel xact. And > that list is ordered by LSN, which is pretty much exactly the order in > which we see the transactions.
Yes indeed. There is even ReorderBufferGetOldestTXN(). > Another somewhat non-intuitive detail is that because ReorderBuffer > switched to Generation allocator for changes (which usually represent > 99% of the memory used during decoding), it does not reuse memory the > way AllocSet does. Actually, it does not reuse memory at all, aiming to > eventually give the memory back to libc (which AllocSet can't do). > > Because of this evicting the youngest transactions seems like a quite > bad idea, because those chunks will not be reused and there may be other > chunks on the blocks, preventing their release. Right. But this raises the question whether we are doing the memory accounting on the right level. If we are doing all this tracking based on ReorderBufferChanges, but then serializing changes possibly doesn't actually free any memory in the operating system, that's no good. Can we get some usage statistics out of the memory context? It seems like we need to keep serializing transactions until we actually see the memory context size drop. -- Peter Eisentraut http://www.2ndQuadrant.com/ PostgreSQL Development, 24x7 Support, Remote DBA, Training & Services