PostgreSQL从入门到精通 - 第40讲:数据库不完全恢复

news/2024/7/9 23:12:14 标签: 数据库, postgresql, oracle

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

第40讲:数据库不完全恢复

PostgreSQL第40讲:1月6日(周六)19:30,钉钉群(35822460)& 视频号(数据库老陈)直播

内容1:描述不完全恢复步骤

内容2:时间点恢复工作原理

内容3:执行一个不完全恢复

不完全恢复应用场景

由于归档日志丢失,完全恢复失败。

所有未归档的wal日志文件都将丢失。

用户错误

一张重要的表被删除。

表中无效的数据被提交。

时间点恢复如何工作

时间点恢复

假设你在2020年4月28日12:05犯了一个错误。您应该删除数据库群集,并使用之前所做的基本备份还原新的数据库群集。然后恢复到12:04:59,停止在错误发生之前。

PITR恢复起始点定位

PITR恢复过程重要的两个因素:

1、从哪里读取WAL段/归档日志?

PITR mode–来自配置参数archive_command中设置的存档目录。

2、从哪里读取检查点位置?

PITR模式–来自备份标签文件。

时间点恢复图示

Recover the database at 12:15:00 along the timelineId 2

不完全恢复类型

recovery_target = 'immediate'  这个参数指定恢复应该在达到一个一致状态后尽快结束。在从一个在线备份中恢复时,这意味着备份结束后的那个点。

recovery_target_name (string)  指定pg_create_restore_point()所创建的已命名的恢复点,进行恢复。

recovery_target_time (timestamp)  指定需要恢复到的时间点。

recovery_target_xid (string)  指定按事务 ID进行恢复。

recovery_target_lsn (pg_lsn)  指定按预写日志位置的LSN进行恢复。

不完全恢复指导方针

仔细遵循所有步骤:

在恢复前后进行整个数据库备份。

始终验证恢复是否成功。

备份和删除归档日志。

不完全恢复和日志

恢复前后检查数据库日志

包含错误信息、提示和txid

执行不完全恢复流程

关闭并备份数据库

还原备份的所有数据文件。

设置需要恢复到的时间点,或者某个位置。

生成recovery.signal文件。

执行数据库启动。

数据库变成读写模式

对全库做个冷备。

基于时间点恢复案例

当前情况:

目前的时间是2022年3月9日中午12点。

EMPLOYEES表已被删除。

表在上午11点45分左右被删除。

数据库活动最小,因为大多数工作人员目前正在开会,意味着从11点45分以后发生的数据更改很少,丢失的数据也会少,因为这一段的数据在做不完全恢复时会丢失。

必须恢复该表。

执行一个基于时间点的恢复

1、还原备份的所有数据文件

tar -vxf /backup/base.tar -C $PGDATA

2、修改postgresql.conf文件

restore_command = 'cp /home/postgres/archive/%f %p'recovery_target_time = '2022-03-09 11:44:59'

3、在$PGDATA目录下生成recovery.signal文件

touch recovery.signal

4、执行数据库启动。

pg_ctl start

5、执行函数,把数据库变成读写模式

select pg_wal_replay_resume();

表空间基于时间点的恢复

经过实验证明,PG不支持表空间不完全恢复,如果做了表空间的时间点恢复,我们发现其它表空间也会做时间点恢复,即整个数据库集群都做时间点恢复,而不是单个表空间做时间点恢复。

CUUG PostgreSQL技术大讲堂系列公开课第40讲-数据库不完全恢复,往期视频及文档,请联系CUUG。


http://www.niftyadmin.cn/n/5311550.html

相关文章

基于ssm的双减后初小教育课外学习生活活动平台的设计与实现论文

双减后初小教育课外学习生活活动平台的设计与实现 摘 要 当下,正处于信息化的时代,许多行业顺应时代的变化,结合使用计算机技术向数字化、信息化建设迈进。以前学校对于课外学习活动信息的管理和控制,采用人工登记的方式保存相关…

基于SSM的图书商城(有报告)。Javaee项目。ssm项目。

演示视频: 基于SSM的图书商城(有报告)。Javaee项目。ssm项目。 项目介绍: 采用M(model)V(view)C(controller)三层体系结构,通过Spring SpringMv…

卷积神经网络|猫狗分类系列--导入kaggle猫狗数据集

解决任何真实问题的重要一步是获取数据,Kaggle提供了大量不同数据科学问题的竞赛。 我们将从 https://www.kaggle.com/competitions/dogs-vs-cats/data 下载猫狗数据集,并对其进行一定的操作,以正确的导入到我们的计算机,为接下…

Shiro之授权

系列文章目录 提示:这里可以添加系列文章的所有文章的目录,目录需要自己手动添加 Shiro之授权 提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 系列文章目录前言一、Shiro之授权权限表的设计…

Js的String的replace(和replaceAll(

EcmaJavascriptJs的String的 replace( 和 replaceAll( 方法 String.prototype.replaceString.prototype.replaceAll 相同点 都是String.prototype的函数都是用于字符串替换都是两个参数第一个参数都可以是正则或字符串第二参数都可以是字符串或者回调函数, 回调会传入一个参…

基于ssm的旅游网页开发与设计+jsp论文

摘 要 信息数据从传统到当代,是一直在变革当中,突如其来的互联网让传统的信息管理看到了革命性的曙光,因为传统信息管理从时效性,还是安全性,还是可操作性等各个方面来讲,遇到了互联网时代才发现能补上自古…

【持续学习系列(五)】《Progressive Neural Networks》

一、论文信息 1 标题 Progressive Neural Networks 2 作者 Andrei A. Rusu*, Neil C. Rabinowitz*, Guillaume Desjardins*, Hubert Soyer, James Kirkpatrick, Koray Kavukcuoglu, Razvan Pascanu, Raia Hadsell 3 研究机构 Google DeepMind, London, UK 二、主要内容 …

JavaWeb——后端案例

五、案例 1. 开发规范—Restful REST(Representational State Transfer),表述性状态转换,是一种软件架构风格 注: REST是风格,是约定方式,不是规定,可以打破描述模块的功能通常使…