Network Security Internet Technology Development Database Servers Mobile Phone Android Software Apple Software Computer Software News IT Information

In addition to Weibo, there is also WeChat

Please pay attention

WeChat public account

Shulou

PostgreSQL DBA (24)-MVCC#4 (xmax in snapshot)

2025-01-17 Update From: SLTechnology News&Howtos shulou NAV: SLTechnology News&Howtos > Database >

Share

Shulou(Shulou.com)06/01 Report--

This section explains the specific meaning of xmax in snapshot through source code.

I. Xmax

The previous section mentioned that PostgreSQL takes snapshots via the txid_current_snapshot() function, in the format xmin : xmax : xip_list, where xmax should be understood as txid + 1 of the last completed transaction (COMMITTED/ABORTED).

See PG source code below:

SnapshotGetSnapshotData(Snapshot snapshot){ /* xmax is always latestCompletedXid + 1 */ xmax = ShmemVariableCache->latestCompletedXid; Assert(TransactionIdIsNormal(xmax)); TransactionIdAdvance(xmax); /* initialize xmin calculation with xmax */ globalxmin = xmin = xmax; ... snapshot->xmax = xmax; ... return snapshot;}

xmax is always latestCompletedXid + 1, txid + 1 of the last completed transaction (COMMITTED/ABORTED)(ShmemVariableCache->latestCompletedXid + 1).

II. References

PostgreSQL Source Code

Welcome to subscribe "Shulou Technology Information " to get latest news, interesting things and hot topics in the IT industry, and controls the hottest and latest Internet news, technology news and IT industry trends.

Views: 0

*The comments in the above article only represent the author's personal views and do not represent the views and positions of this website. If you have more insights, please feel free to contribute and share.

Share To

Database

Wechat

© 2024 shulou.com SLNews company. All rights reserved.

12
Report