postgres:清理过程(3),冻结过程

本文深入探讨了数据库的冻结过程,包括惰性模式和迫切模式。惰性模式仅扫描包含死元组的页面,而迫切模式则全面扫描所有页面以确保所有需要冻结的元组都被处理。当pg_database.datfrozenxid小于OldestXmin-vacuum_freeze_table_age时,系统将触发迫切模式。文章还提到了9.5版本之后的改进,提高了冻结效率。
摘要由CSDN通过智能技术生成

冻结过程

冻结过程包含两种:惰性模式和迫切模式,冻结过程通常是以惰性的模式运行,但是当满足条件,也会以迫切模式运行。在惰性模式下,冻结过程仅使用目标表对应的VM扫描死元组的页面迫切模式相反,它会扫描所有的页面,无论是否包含死元组,都会更新与冻结过程相关的系统视图,并在可能的情况下删除CLOG

惰性模式

开始冻结处理时,pg计算freezelimit_txid,并冻结t_xmin小于freezelimit_txid的元组。公式:

 

freezeLimit_txid=(OldestXmin−vacuum_freeze_min_age)  #vacuum_freeze_min_age是一个配置参数,默认值为:50,000,000

OldestXmin是当前正在运行最早的事务标识。比如正在运行vacumm,有三个事务txid分别为:100 、101、102,那么OldestXmin=100。如果不存在事务,OldestXmin就是当前vacuum命令的事务标识。举例说明惰性模式:

假如OldestXmin为50,002,500
第0页面:

三条元组被冻结,因为所有元组t_ximin都小于2500,此外,以为tuple1为死元组,所以在该清理过程中被删除。

第1页面:

通过引用VM,发现该页面所有元组都可见,清理过程跳过了对该页面的清理。

第2页面:

tuple7和tuple8被冻结,且tuple7被移除。。

如上面例子所展示,因为惰性模式可能跳过页面,它可能无法冻结所需要冻结的元组。

迫切模式

迫切模式弥补了惰性模式的问题,会扫描所有页面,检查表中所有元组,更新相关的系统视图,并在可能时删除不必要的CLOG与页面。

当满足以下条件,会执行迫切模式:

pg_database.datfrozenxid<(OldestXmin−vacuum_freeze_table_age),其中datfrozenxid是系统视图pg_database中的列,并保存每个数据中最老的已经冻结的事务标识。

vacuum_freeze_table_age是系统配置参数,默认值为:150,000,000。假设pg_database.datfrozenxid=1821

  •  OldestXmin−vacuum_freeze_table_age=2000 满足迫切模式:pg_database.datfrozenxid<(OldestXmin−vacuum_freeze_table_age),即1821<2000,小于2000需要冻结
  •  freezeLimit_txid=(OldestXmin−vacuum_freeze_min_age)=100,002,000,对于惰性模式满足这个条件的也需要冻结

第0页:

即使所有元组都被冻结,也会检查tuple2和tuple3(9.5或者更低版本)

第1页:

冻结所有页面,因为t_xmin小于freeelimint_txid。在惰性模式下,会跳过此页面,因为所有tuple都可见

第2页:

除了tuple11都冻结。

冻结一张表后,该表的pg_class.relfrozenxid将被更新。在完成清理过程之前,必要时会更新pg_database.datfrozenxid,即database下所有table都被更新后,会更新pg_databse.datfrozenxid.

改进迫切模式的冻结过程

9.5以及以下版本的迫切模式,导致table的所有页面都要被扫描,效率很低。9,5以后,使用VM存储哪些页面都被冻结,则可以跳过该页面,提高效率。

 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
如果你在执行 `docker tag postgres:latest myusername/postgres:latest` 命令时出现了 `Error response from daemon: No such image: postgres:latest` 的错误提示,可能是因为本地没有名为 `postgres:latest` 的镜像。在这种情况下,你需要先构建 `postgres` 镜像,然后再使用 `docker tag` 命令为其添加一个新标签。 请按照以下步骤操作: 1. 进入包含 `docker-compose.yml` 文件的目录。 2. 执行以下命令来构建 `postgres` 服务的镜像: ``` docker-compose build postgres ``` 该命令将会使用 `docker-compose.yml` 文件中定义的 `postgres` 服务的配置信息来构建镜像,并将其命名为 `postgres`。 3. 执行以下命令来查看构建的镜像: ``` docker images ``` 该命令将会列出本地所有的 Docker 镜像,你可以在其中找到刚刚构建的 `postgres` 镜像。 4. 执行以下命令来为 `postgres` 镜像添加一个新的标签: ``` docker tag postgres:latest myusername/postgres:latest ``` 该命令会将 `postgres:latest` 镜像的一个新标签 `myusername/postgres:latest`,以便将其推送到 Docker Hub 或其他镜像仓库中。 注意:在使用 `docker-compose build` 命令构建镜像时,Docker Compose 会根据 `docker-compose.yml` 文件中定义的服务配置信息来构建镜像。因此,如果你需要修改服务的配置信息,例如修改 `postgres` 服务的 Dockerfile 或其他构建参数,你需要在重新构建镜像前修改 `docker-compose.yml` 文件中相应的配置信息。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值