Обсуждение: pgsql: Track latest completed xid as a FullTransactionId.

Поиск
Список
Период
Сортировка

pgsql: Track latest completed xid as a FullTransactionId.

От
Andres Freund
Дата:
Track latest completed xid as a FullTransactionId.

The reason for doing so is that a subsequent commit will need that to
avoid wraparound issues. As the subsequent change is large this was
split out for easier review.

The reason this is not a perfect straight-forward change is that we do
not want track 64bit xids in the procarray or the WAL. Therefore we
need to advance lastestCompletedXid in relation to 32 bit xids. The
code for that is now centralized in MaintainLatestCompletedXid*.

Author: Andres Freund
Reviewed-By: Thomas Munro, Robert Haas, David Rowley
Discussion: https://postgr.es/m/20200301083601.ews6hz5dduc3w2se@alap3.anarazel.de

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/3bd7f9969a240827bc2effa399170b7565238fd2

Modified Files
--------------
src/backend/access/transam/varsup.c |  50 ++++++++++++++
src/backend/access/transam/xlog.c   |   4 +-
src/backend/storage/ipc/procarray.c | 129 +++++++++++++++++++++++++++++-------
src/include/access/transam.h        |  37 ++++++++++-
4 files changed, 191 insertions(+), 29 deletions(-)