资讯
HOME
资讯
正文内容
tx恢复备份nand postgresql从小白到高手 - 第40讲:数据库不完全恢复
发布时间 : 2024-11-24
作者 : 小编
访问数量 : 23
扫码分享至微信

postgresql从小白到高手 - 第40讲:数据库不完全恢复

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。

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

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。

相关问答

switchtx系统授权文件丢失咋办?

你好,如果您丢失了SwitchTX系统的授权文件,建议您联系SwitchTX系统的厂商或技术支持团队,说明情况并提供相关证明文件,以便他们为您重新生成授权文件。您也...

linux系统误删文件夹怎么 恢復 -ZOL问答

ext4文件系统上删除文件,可以用extundelete进行恢复。具体步骤已经有高手写好了:http://jingyan.baidu.com/article/3c48dd3493221de10be3...

电脑微信记录没了能 恢复 吗,我只升级了一下系统然后记录就没...

如果是微信的话、是恢复不了的、TX太黑了、但是其他东西的话可以恢复

tx 和大气层可以同时使用吗?

**不可以**。TX和大气层是两个不同的系统,它们在硬件和软件方面都有不同的特点和限制。同时使用两个系统可能会造成冲突和不稳定的问题,因此不建议同时使用。...

联想N480如何 恢復 出厂设置?-ZOL问答

http://www.lenovomobile.com/support/map.aspx祝您生活愉快,谢谢!有用(0)回复780311联想A320t手机恢复出厂设置在设置-备份和重置-恢复出...

新中大,凭证已录入,如何修改初始数据?

1、做一下账务备份,建一个新帐套恢复一下,看一下行不行,行的话做新备份恢复到原帐套2、建一个新帐套,用上个月的备份恢复进去,利用凭证传入传出功能将本月...

什么是镜像 备份 ?

镜像备份,顾名思义,就是像照镜子一样,把现在系统上所有的文件都复制一份作为备份。用镜像文件备份,必须要保证镜像文件的完整,出现任何损失之后,镜像文件...

惠普笔记本电脑如何 恢復 BIOS默认值?-ZOL问答

这将恢复默认设置,并重新启动计算机。4.计算机将重新启动,并且BIOS设置将恢复为出厂时的默认值。请注意,在执行此操作之前,请确保您已经备份了重要数据。另...

Win7 64位操作系统出现RICHTX32.OCX未注册-ZOL问答

这种故障是因为程序需要RICHTX32.OCX文件,而这个文件又没有被系统注册,所以,我们要首先卸载这个控件,然后再重新注册该文件。具体操作步骤如下:(1)首先单击...

华硕 tx 300ca怎样重装系统?

华硕Tx300CA可通过两种方式重装系统:一是使用刻录好的Windows安装盘进行安装,需要先进入BIOS将启动设备调整为光驱;二是恢复出厂设置,需要在开机时按下F9进...

 卡塔尔国  数据恢复培训 
王经理: 180-0000-0000(微信同号)
10086@qq.com
北京海淀区西三旗街道国际大厦08A座
©2024  上海羊羽卓进出口贸易有限公司  版权所有.All Rights Reserved.  |  程序由Z-BlogPHP强力驱动
网站首页
电话咨询
微信号

QQ

在线咨询真诚为您提供专业解答服务

热线

188-0000-0000
专属服务热线

微信

二维码扫一扫微信交流
顶部