首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在postgresql中,txid_current()中时代的含义是什么?

在postgresql中,txid_current()中时代的含义是什么?
EN

Stack Overflow用户
提问于 2018-03-10 21:29:33
回答 1查看 979关注 0票数 10

https://www.postgresql.org/docs/10/static/functions-info.html#FUNCTIONS-TXID-SNAPSHOT

内部事务ID类型(xid)为32位宽,每40亿个事务封装一次。然而,这些函数导出了一种64位格式,该格式是用一个“划时代”计数器扩展的,这样它就不会在安装过程中包装起来。

这个时代在这句话中的意义是什么?这是xid达到40亿次事务并被重新调整为零的多少次计数器吗?

我是否正确地理解txid_current()返回一个64位数,这个数字基本上是由两个32位数字连在一起组成的?前32位是一个划时代计数器(从0开始),最后32位是xid?

我假设当xid达到最大值时,划时代计数器将被撞到0,而xid重置为0。我猜想,这基本上使txid_current()的行为像一个正常的64位数字。

它就是这样工作的吗?我很难理解这一点。

EN

回答 1

Stack Overflow用户

发布于 2019-07-12 05:57:10

Epoch用于防止txid_current()从零开始包装(或者确切地说从3开始,因为值0、1、2在内部重复使用)。

它的工作原理是:

Postgres有一个内部32位xid计数器,与txid_current()返回的值不同。内部xid环绕并重新设置其计数在每一个环绕。

另一方面,txid_current()返回64位(bigint),其中高位是一个划时代的增量,每xid环绕一次,而不是从零开始。

因此,在每一次循环中,txid_current()的高位数都会被修改,以防止txid重置,而txid则会不断增加,直到达到64位限制(有时在我们都死后很久的将来)。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49214219

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档