PostgreSQL从入门到精通教程 - 第39讲:数据库完全恢复
itomcoil 2025-09-03 00:06 3 浏览
PostgreSQL从小白到专家,是从入门逐渐能力提升的一个系列教程,内容包括对PG基础的认知、包括安装使用、包括角色权限、包括维护管理、、等内容,希望对热爱PG、学习PG的同学们有帮助,欢迎持续关注CUUG PG技术大讲堂。
第39讲:数据库完全恢复
PostgreSQL第39讲:12月23日(周六)19:30,钉钉群(35822460)& 视频号(数据库老陈)直播
内容1:描述介质恢复
内容2:执行非归档模式下恢复
内容3:执行归档模式下完全恢复
内容4:执行基于表空间的完全恢复
内容5:执行只读数据库恢复
介质恢复
用于恢复丢失或损坏的当前数据文件或控制文件
需要显式调用
操作如下:
从备份中恢复文件
恢复的文件会应用归档日志和在线重做日志进行数据重构
恢复步骤
执行数据文件转储和恢复
使用操作系统命令tar/cp转储数据文件
使用pg_ctl start对数据文件进行恢复
非归档模式恢复
在非归档模式下,必须恢复数据目录下所有的文件和目录:
所有$PGDATA目录下的子目录 base、global、pg_wal...
所有$PGDATA目录下的文件 postgresql.conf、pg_hba.conf...
非归档模式恢复优缺点
优势
易于执行,出错风险低
恢复时间是转储所有文件所需的时间
缺点
数据丢失,必须手动重新应用
整个数据库将恢复到上一次完整关闭备份的位置
非归档模式恢复
归档模式恢复
完全恢复
使用wal数据或增量备份
将数据库更新到最新的时间点
应用所有wal日志记录的更改
不完全恢复
使用备份和wal日志生成数据库的非当前版本
完全恢复
确认数据库关闭
恢复数据文件
如果是全库备份,哪怕是损坏了一个数据文件,也要转储备份的所有数据文件
如果是单独表空间(除了global)备份,哪怕损坏了表空间下的一个数据文件,也要转储备份的所有数据文件
修改postgresql.conf文件
生成recovery.signal空文件
启动数据库(recovery)
归档模式完全恢复优缺点
优势
将所有数据恢复到最新点(故障点)
恢复时间是转储数据文件和应用所有归档日志文件所需的时间
缺点
必须具有自您要从中恢复的备份以来的所有归档日志文件
执行一个基于数据库备份的完全恢复
示例(恢复前备份pg_wal目录下所有文件)
1、使用tar包进行恢复
tar -zvxf /backup/base.tar.gz -C $PGDATA
2、修改postgresql.conf文件
restore_command = 'cp /home/postgres/archives/%f %p'
recovery_target_timeline = 'latest'
3、生成recovery.signal空文件
touch recovery.signal
4、启动数据库
pg_ctl start
时间线和时间线历史文件
timelineId(时间线)
每当做了一次完全或者不完全恢复后,数据库的时间线就会发生变化,意味着从失败点后重新开始新的生命轨迹,同时用时间线历史文件来记录。
timelineId 和 wal文件名关系
时间线的改变导致wal名字发生变化
当完成对数据库的恢复后,会产生新的wal文件,其命名规则为在原来的段文件名字中用新的时间线替换原来的时间线,其它不变。
时间线和时间线历史文件
Timeline History File
历史文件会在pg_wal中生成,同时复制到归档目录下,命名规则如下所示:
“8-digit new timelineId”.history 比如:00000002.history
时间线历史记录文件至少包含一行,每行由以下三项组成:
timelineId –用于恢复的归档日志的timelineId。
LSN –发生WAL段切换的LSN位置
reason –人类可读的时间线为什么改变的解释。
比如:postgres> cat
/home/postgres/archivelogs/00000002.history
0/A000198before 2020-4-28 12:05:00.861324+00
注意上面1是行号,也代表数据库恢复过的次数。这个文件不要删除,否则会影响数据库恢复。
执行一个基于表空间备份的完全恢复
PG支持基于表空间(除了pg_global之外)级别的完全恢复,因为pg_global表空间比较特殊,其中包括控制文件,而控制文件不能使用备份的进行恢复。
1、转储备份的表空间目录到目标位置
cp -rf /backup/PG_12_201909212 /home/postgres/tblspc/
2、转储backup_lable文件到$PGDATA目录下
cp /backup/backup_lable $PGDATA
3、创建recovery.signal
4、修改postgresql.conf文件
restore_command = 'cp /home/postgres/archives/%f %p'
recovery_target_timeline = 'latest'
5、启动数据库,表空间所包含的表能够实现完全恢复
pg_ctl start
只读数据库的恢复
执行一个只读数据库的恢复
1、把数据库变成只读状态
ALTER DATABASE new_db1 SET default_transaction_read_only=on;
2、单独备份new_db1数据库目录
3、如果new_db1数据库目录损坏,关闭数据库,转储备份的目录到目标位置
4、打开数据库
*PG不支持单个数据库完全恢复。
CUUG PostgreSQL技术大讲堂系列公开课,往期视频及文档,请联系CUUG客服。
相关推荐
- Postgres是个六边形战士,其他很多工具是没必要的
-
你只是想部署一个简单应用,一个仪表盘、一个聊天工具,或者个人项目。突然之间,你得启动Redis做缓存,上Elasticsearch做搜索,用Firebase实现实时同步,配置无服务器函数的...
- PostgreSQL开发与实战(5)备份管理pg_probackup
-
作者:太阳一、pg_probackup概述pg_probackup是一款免费的postgres数据库集群备份工具,与其他备份工具相比,它主要有如下一些优势:提供增量备份,增量备份一定程度上可以节省磁...
- 了解 PostgreSQL 的 MVCC 可见性基本检查规则
-
1.引言根据VadimMikheev的说法,PostgreSQL的多版本并发控制(MVCC)是一种“在多用户环境中提高数据库性能的高级技术”。该技术要求系统中存在同一数据元组的多个“版本”,...
- PostgreSQL初学者需要知道一些技巧
-
PostgreSQL作为一个优雅而且稳健的数据库越来越被大家所采纳,除了Mysql以外很多人都开始接触并学习PostgreSQL。但是PostgreSQL和传统的一些数据库系统还有有点点小小的鸿沟,有...
- Python - 操作 PostgreSQL 数据库的基本方法与代码
-
本文记录在Python编程中操作PostgreSQL数据库的基本方法与实现代码,包括连接数据库、创建数据表、插入/更新/删除数据表中的记录、函数调用、存储过程调用及事务处理等。获取数据库首先把连接数据...
- 详解PostgreSQL 12.2时间点恢复 (PITR)
-
概述PostgreSQL提供了不同的方法来备份和恢复数据库,可以是某一时刻数据库快照的完整备份或增量备份,可以使用SQL转储或文件系统级别的备份,在增量备份的基础上还可以实现基于时间点恢复。这...
- PostgreSQL 17即将发布,新功能Top 3
-
按照计划,PostgreSQL17即将在2024年9月份发布,目前已经发布了第三个Beta版本,新版本的功能增强可以参考ReleaseNotes。本文给大家分享其中3个重大的新...
- PostgreSQL从入门到精通教程 - 第39讲:数据库完全恢复
-
PostgreSQL从小白到专家,是从入门逐渐能力提升的一个系列教程,内容包括对PG基础的认知、包括安装使用、包括角色权限、包括维护管理、、等内容,希望对热爱PG、学习PG的同学们有帮助,欢迎持续关注...
- PostgreSQL建库说明_postgresql能创建多少表
-
1.数据库逻辑结构介绍在一个PostgreSQL数据库系统中,数据库:一个PostgreSQL数据库服务下可以管理多个数据库,当应用连接到一个数据库时,一般只能访问这个数据库中的数据,而不能访问其他...
- 为什么delete后磁盘空间没有释放而truncate会释放?
-
背景因项目需求,需要清理一批旧数据,腾出空间给新数据,让同事负责这件事。料想会很顺利,但很快找到我,并告知在postgresql中把一张大的数据表删除掉了,查询表的size并没有改变。我震惊了,问他怎...
- PostgreSQL技术内幕6:PostgreSQL索引技术
-
0.简介本文主要介绍PG的索引技术,包含PG支持的索引类型,语法,查看方式,以及其中B-Tree索引的原理解析和源码解读。1.PG索引类型介绍PG支持多种索引类型:B-tree、Hash、GiST、...
- PostGreSQL历史_postgresql序列查询
-
1973UniversityINGRES(起源于IBMSystemR的一系列文档,MichaelStonebrakerandEugeneWong)1982INGRES1985...
- Retool 如何升级主应用 4TB 的 PostgreSQL 数据库
-
本文最初发布于Retool官方博客。Retool的云托管产品基于一个在微软Azure云中运行的4TB的Postgres数据库。去年秋天,我们把这个数据库从Postgres9.6...
- ArcGIS Desktop直连PostgreSQL安装及配置图解(windows)
-
目录1PostgreSQL11.0安装及配置2psqlODBC安装及配置3PostGIS安装及配置4pgAdmin4使用入门5空间数据导入5.1将PostgreSQL的bin文件路径添加...
- 基于patroni+etcd打造可自动故障转移的PostgreSQL集群
-
作者:杭州美创科技有限公司得益于PostgreSQL的开源特性,越来越多的第三方集群管理软件填补了PostgreSQL在集群方面的易用性和可靠性,patroni+etcd提供了一系列的集群管理方案。e...
- 一周热门
- 最近发表
-
- Postgres是个六边形战士,其他很多工具是没必要的
- PostgreSQL开发与实战(5)备份管理pg_probackup
- 了解 PostgreSQL 的 MVCC 可见性基本检查规则
- PostgreSQL初学者需要知道一些技巧
- Python - 操作 PostgreSQL 数据库的基本方法与代码
- 详解PostgreSQL 12.2时间点恢复 (PITR)
- PostgreSQL 17即将发布,新功能Top 3
- PostgreSQL从入门到精通教程 - 第39讲:数据库完全恢复
- PostgreSQL建库说明_postgresql能创建多少表
- 为什么delete后磁盘空间没有释放而truncate会释放?
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)