当前位置: CUUG培训中心->优技培训 > PG技术大讲堂 - Part 11:PostgreSQL控制文件作用与管理

PG技术大讲堂 - Part 11:PostgreSQL控制文件作用与管理

2023-03-16作者:Oracle WDP中心来源:Oracle培训中心

PostgreSQL从小白到专家,是从入门逐渐能力提升的一个系列教程,内容包括对PG基础的认知、包括安装使用、包括角色权限、包括维护管理、、等内容,希望对热爱PG、学习PG的同学们有帮助,欢迎持续关注CUUG PG技术大讲堂。

Part 11:PostgreSQL控制文件作用与管理

内容1:PostgreSQL控制文件位置

内容2:PostgreSQL控制文件内容

内容3:PostgreSQL控制文件维护

内容4:PostgreSQL控制文件备份

内容5:PostgreSQL控制文件恢复


11.1、控制文件位置

控制文件位置与大小

逻辑位置:存放在pg_global表空间中

物理位置与名字:$PGDATA/global/pg_control

控制文件的物理大小是8K

控制文件内容尽量保持小于512个字节


11.2、控制文件内容

· initdb时生成的静态信息

pg_control version number: 1201

Catalog version number: 201909212

Database system identifier: 6744130188358323871

Maximum data alignment: 8

Database block size: 8192

Blocks per segment of large relation: 131072

WAL block size: 16384

Bytes per WAL segment: 16777216

Maximum length of identifiers: 64

Maximum columns in an index: 32

Maximum size of a TOAST chunk: 1996

Date/time type storage: 64-bit integers

Float4 argument passing: by value

Float8 argument passing: by value

· postgresql.conf中的配置信息

wal_level setting: replica

wal_log_hints setting: on

max_connections setting: 1000

max_worker_processes setting: 8

max_wal_senders setting: 10

max_prepared_xacts setting: 0

max_locks_per_xact setting: 64

track_commit_timestamp setting: off

· write-ahead logging以及checkpoint的动态信息

Latest checkpoint location: 2E/CD32D270

Latest checkpoint's REDO location: 2E/CD32D270

Latest checkpoint's REDO WAL file: 000000110000002E000000CD

Latest checkpoint's TimeLineID: 17

Latest checkpoint's PrevTimeLineID: 17

Latest checkpoint's full_page_writes: on

Latest checkpoint's NextXID: 0:538902

Latest checkpoint's NextOID: 385511

Latest checkpoint's NextMultiXactId: 5

……

Time of latest checkpoint: Sat 18 Jul 2020 10:11:14 PM EDT

Fake LSN counter for unlogged rels: 0/3E8

Backup start location: 0/0

Backup end location: 0/0

End-of-backup record required: no


11.3、控制文件维护

1、固定部分

 初始化数据库时产生,固定不变

2、有些信息随时更新

 如果发生检查点、备份、日志切换等操作,则自动更新

3、postgres.conf相关参数被更新

 如果配置文件中重要的相关参数被修改,则也会自动更新

4、数据库备份时会一起备份

5、不能手动修改该文件

6、启动和恢复数据库时需要,当前没有避免发生单一故障点而设计的保护策略


11.4、控制文件备份

备份方式(与数据库备份一起备份,一起恢复,不能单独备份)

1、tar命令

tar -jcv -f baseline.tar.bz2 $PGDATA

2、pg_basebackup命令

pg_basebackup -D bk1 -Ft -z –P

3、pg_rman命令

pg_rman backup --backup-mode=full -B /home/postgres/pg_rman_bk/ -C -P


11.5、控制文件恢复

重建控制文件

Pg10版本以前版本使用pg_resetxlog工具

Pg10及以后版本使用pg_resetwal工具

pg_resetwal工具需要下面四个参数:

· 1、

-l XLOGFILE force minimum WAL starting location for new transaction log

 ( XLOGFILE强制新事务日志的最小WAL起始位置)

定位办法:pg_wal下面创建的最大的日志文件,编号+1

cd /usr/local/pg12.2/data/pg_wal/

ll

-rw------- 1 postgres postgres 270 Mar 21 09:40 00000010.history

-rw------- 1 postgres postgres 16777216 Jul 19 06:19 0000001100000038000000C4

-rw------- 1 postgres postgres 16777216 Jul 19 06:16 0000001100000038000000C5

-rw------- 1 postgres postgres 16777216 Jul 19 06:17 0000001100000038000000C6

-rw------- 1 postgres postgres 16777216 Jul 19 06:17 0000001100000038000000C7

确定-l 的参数值为:

-l 0000001100000038000000C8

· 2、

-O OFFSET set next multitransaction offset

在pg_multixact/members下面,取最大值加1然后乘以65536.转换成16进制为100000,然后末尾添加4个0

-O=0x1000000000

步骤:

1、进入相应目录

cd $PGDATA/pg_multixact/members/

2、查看文件

ll-rwxr-x--- 1 postgres postgres 8192 Jul 18 22:11 0000

3、计算结果

-O=0x1000000000

· 3、

-m =MXID,MXID set next and oldest multitransaction ID

在pg_multixact/offsets下面,找到最大的文件编号,+1 后面跟上4个0

如:0000

-m =0x00010000,0x00010000

步骤:1、进入相应目录

cd $PGDATA/pg_multixact/offsets

2、查看文件

-rwxr-x--- 1 postgres postgres 8192 Jul 19 05:57 0000

3、计算结果

-m=0x00010000,0x00010000

· 4、

-x XID set next transaction ID

在pg_xact下面,找到最大的文件编号,+1 后面跟上5个0

如:0000

-x = 0x000100000

步骤:1、进入相应目录

cd $PGDATA/pg_xact/

2、查看当前文件

lltotal 140-rwxr-x--- 1 postgres postgres 139264 Jul 18 23:21 0000

3、计算-x值

-x=0x000100000


执行重建控制文件语句:

cd $PGDATA/global

touch pg_control

pg_resetwal -l 0000001100000038000000CC -O 0x1000000000 \

-m 0x00010000,0x00010000 -x 0x000100000 -f $PGDATA

pg_controldata

启动数据库:

pg_ctl start


以上就是Part 11 - PostgreSQL控制文件作用与管理 的内容,欢迎进群一起探讨交流QQ交流群:752027153

微信交流群:联系客服拉你进微信PG交流群

钉钉交流群:35822460,钉钉群有专门讲解公开课

往期课程及视频,联系cuug咨询老师

  • PolarDB for PostgreSQL 云原生数据库的优势
  • PolarDB for PostgreSQL简介
  • PolarDB MySQL版和PostgreSQL版相同产品架构
  • PolarDB-PG 架构之存储计算分离架构
  • PolarDB分布式版产品架构
  • PolarDB数据库优势何在
  • PolarDB数据库有几种引擎
  • PostgreSQL技术大讲堂 - 第15讲:数据文件与块存储结构
  • 阿里云瑶池数据库PolarDB获2023网信自主创新“尖锋榜”- 优秀产品奖
  • 开源数据库技术沙龙走进温州大学
  • 什么是PolarDB数据库
  • 5月12日,开源数据库技术沙龙 · 温州站,圆满结束!
  • 2023年天财珠江学院《国产数据库工作室》纳新活动
  • CUUG、阿里云和渤海大学组建《国产数据库工作室》
  • PostgreSQL的PG证书是哪里颁发的认证
  • PostgreSQL技术大讲堂 - 第16讲:元组(行)结构与dml操作
  • PostgreSQL技术大讲堂 - 第17讲:Vacuum空间管理工具
  • 恭喜闻同学通过OCM认证,19c OCM已开新班
  • PolarDB PostgreSQL版产品架构(图)
  • PolarDB PostgreSQL版常见问题
  • OCM 19c认证培训,本周CUUG新班开课
  • PG认证PGCP全称是什么?附证书图片
  • PostgreSQL认证PGCA全称是什么
  • PostgreSQL认证证书电子版怎么查
  • 从小白到专家 PostgreSQL技术大讲堂 - Part 8:PG对象权限管理
  • 第12届pg中文社区《PostgreSQL中国技术大会》即将开启
  • Oracle OCM 12c 绝版证书
  • PG技术大讲堂 - 第13讲:PostgreSQL Full-Page Writes 全页写
  • PG技术大讲堂 - 第14讲:PostgreSQL 检查点
  • PG认证培训,Postgresql证书是什么样的
  • PG证书图片 - PostgreSQL数据库培训认证证书
  • 渤海大学《国产数据库工作室》成立大会
  • 信创pg认证 - postgresql数据库管理员认证
  • PolarDB For PostgreSQL跨机并行查询功能
  • 2023年2月,cuug王同学通过ocm 12c认证考试成绩
  • 2023年PostgreSQL认证培训红头文件!
  • 直播:从小白到专家 PG技术大讲堂,第6讲:PostgreSQL用户与角色
  • 2022·第十二届PostgreSQL中国技术大会成功举办
  • Oracle ocp线下培训班什么时候开放
  • PGCM全称是什么?PostgreSQL高级认证
  • PG初级和PG中级认证 - 证书官方查询网址
  • PG技术大讲堂 - Part 10:PostgreSQL数据库管理
  • PG技术大讲堂 - Part 11:PostgreSQL控制文件作用与管理
  • ocp认证难度以及证书价值
  • ocp是什么意思(oracle中级认证)
  • ocp证书含金量,2023年还有必要考ocp认证吗
  • ocp证书怎么考,报考流程
  • PG技术大讲堂 - Part 11:PostgreSQL控制文件作用与管理
  • PG技术大讲堂 - 第12讲:PostgreSQL wal作用与管理
  • PostgreSQL中文社区线下沙龙【4月1日 西安站】
  • http://www.ujpeixun.com/sitemap.txt
  • http://www.firstyuding.com/sitemap.txt
  • http://www.hcjggs.com/sitemap.txt
  • http://www.gzslhs.com/sitemap.txt
  • http://www.fuhua-pet.com/sitemap.txt
  • http://www.gbaiyou.com/sitemap.txt
  • http://www.hlflowers.com/sitemap.txt
  • http://www.fh-soft.com/sitemap.txt
  • http://www.gwwp168.com/sitemap.txt
  • http://www.fljsyy.com/sitemap.txt
  • http://www.gth163.com/sitemap.txt