PG控制文件的管理与重建

一.控制文件位置与大小

逻辑位置:pgpobal 表空间中

物理位置:PGDATA/global/pg_control --pg_global表空间的物理位置就在PGDATA/global文件夹下

物理大小:8K

二.存放的内容

1.数据库初始化的时候生成的永久化参数,无法更改的参数。
比如:版本号,数据库块的大小。
2.实例初始化参数文件(postgresql.conf)中的配置信息
3.可以更改的信息:比如检查点信息

三.控制文件的维护

1.控制文件的信息随时更新,如果发生检查点,备份,日志切换,则自动更新

2.初始化参数文件(postgres.conf)文件中的相关参数被修改,也会自动更新

3.数据库备份的时候会一起备份

4.该文件是二进制文件

四.控制文件重建

使用pg_resetwal工具。

模拟控制文件丢失:

1.寻找 -l 参数:

在pg_wal 目录下寻找最大的日志文件号,让它+1

如图中就变成:000000010000000000000002

2.寻找 -o 参数:

如图中,(0+1)*65536 再转换成16进制,再在末尾加上四个0 ------->0x1000000000。

3.寻找 -m参数:

直接最大编号+1 ,再加上四个0, 如图变成0x00010000,0x00010000。

4.寻找 -x参数

最大文件号+1,再在后面加五个0.

如图变成 0x00010000

5.touch一个新的控制文件

执行语句

复制代码
pg_resetwal -l 000000010000000000000002 -O 0x1000000000 -m 0x00010000,0x00010000 -x 0x00010000 -f $PGDATA
相关推荐
jiayou641 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤2 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区3 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1773 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再4 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
tryCbest4 天前
数据库SQL学习
数据库·sql
jnrjian4 天前
ORA-01017 查找机器名 用户名 以及library cache lock 参数含义
数据库·oracle