首页 > 数据库 >PostgreSQL从入门到精通教程 - 第42讲:pg_rman部署与使用

PostgreSQL从入门到精通教程 - 第42讲:pg_rman部署与使用

时间:2024-01-19 13:56:24浏览次数:34  
标签:11 PostgreSQL 21 备份 42 pg 2022 rman

 

 

 

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

 

第42讲:pg_rman部署与使用

 

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

内容1:pg_rman简介

内容2:Pg_rman部署

内容3:使用pg_rman进行备份与恢复

内容4:制定自动维护策略

 

pg_rman简介

pg_rman是一款开源的备份恢复软件,支持在线和基于PITR的备份恢复方式。

pg_rman类似于oracle的rman,可以进行全量、增量、归档日志的备份。

https://github.com/ossc-db/pg_rman/releases,注意跟数据库版本配套。

pg_rman特点:

使用简单,一个命令即可完成备份和恢复。

支持在线全备、增量、归档日志备份

支持备份压缩。

支持自动备份维护,自动删除过期的WAL备份文件。

支持备份验证。

支持基于PITR的配置文件生成器。

 

pg_rman部署

1、上传安装包并解压安装(postgres用户安装)

# tar vxf pg_rman-1.3.9-pg12.tar.gz

# cd pg_rman-1.3.9-pg12

# make

# make install

默认会安装到$PG_HOME/bin目录下。

2、初始化环境

--设置备份目录,在用户配置文件里面添加如下:

export BACKUP_PATH=/home/postgres/pg_rman_bk1

--让环境变量生效

source .bash_profile

--初始化备份目录,验证归档路径,日志目录,同时在备份路径下产生跟目标数据库相关的文件。

$ pg_rman init

INFO: ARCLOG_PATH is set to '/home/postgres/arch'

INFO: SRVLOG_PATH is set to '/usr/local/pg12.2/data/pg_log'

--查看备份路径下的内容:

20200603 backup pg_rman.ini system_identifier timeline_history

 

pg_rman命令

语法:

pg_rman [OPTION] COMMAND

COMMAND:

init 初始化备份目录

backup 在线备份

restore 恢复

show 查看备份历史

validate 验证备份

delete 从知识库中删除备份信息

purge 从备份目录中删除已实际的备份文件

 

全量备份

对数据库做全备:

pg_rman backup --backup-mode=full -C -P

验证数据库备份(必须要验证,否则后续无法做增量备份):

pg_rman validate

查看备份信息:

pg_rman show

=====================================================================

StartTime EndTime Mode Size TLI Status

=====================================================================

2022-11-16 21:41:18 2022-11-16 21:41:21 FULL 139MB 3 OK

 

增量备份

对数据库做增量备份:

pg_rman backup --backup-mode=incremental

验证数据库备份(必须要验证,否则后续无法做增量备份):

pg_rman validate

查看备份信息:

pg_rman show

=====================================================================

StartTime EndTime Mode Size TLI Status

=====================================================================

2022-11-16 21:44:32 2022-11-16 21:44:34 INCR 33MB 3 OK

2022-11-16 21:41:18 2022-11-16 21:41:21 FULL 139MB 3 OK

 

归档备份

归档备份:

pg_rman backup --backup-mode=archive

验证数据库备份(必须要验证,否则后续无法做增量备份):

pg_rman validate

查看备份信息:

pg_rman show

=====================================================================

StartTime EndTime Mode Size TLI Status

=====================================================================

2022-11-16 21:51:50 2022-11-16 21:51:51 ARCH 16MB 3 OK

2022-11-16 21:44:32 2022-11-16 21:44:34 INCR 33MB 3 OK

2022-11-16 21:41:18 2022-11-16 21:41:21 FULL 139MB 3 OK

 

完全恢复

恢复数据文件:

pg_rman restore

恢复过程会自动修改和生成需要的文件:

INFO: restoring WAL files from backup "2022-11-16 21:51:50"

INFO: restoring online WAL files and server log files

INFO: add recovery related options to postgresql.conf

INFO: generating recovery.signal

INFO: restore complete

HINT: Recovery will start automatically when the PostgreSQL server is started.

启动数据库:

pg_ctl start

 

时间点恢复

恢复数据文件:

pg_rman restore --recovery-target-time="2022-11-16 22:05:22"

恢复过程会自动修改和生成需要的文件:

INFO: restoring WAL files from backup "2022-11-16 21:51:50"

INFO: restoring online WAL files and server log files

INFO: add recovery related options to postgresql.conf

INFO: generating recovery.signal

INFO: restore complete

HINT: Recovery will start automatically when the PostgreSQL server is started.

启动数据库:

pg_ctl start

执行函数:

Select pg_wal_replay_resume() ;

 

备份数据维护

删除指定时间点的备份,如果只有一个可用备份,则需要加上-f选项:

pg_rman delete "2022-11-16 21:44:34" -f

上面删除操作只是删除pg_rman目录中的记录,实际的备份数据没有删除,需要purge才能够真正删除:

pg_rman purge

INFO: DELETED backup "2022-11-16 21:44:32" is purged

INFO: DELETED backup "2022-11-16 21:41:18" is purged

 

pg_rman.ini文件

可以根据备份策略,制定自动维护配置,在进行备份操作时会自动检查:

RCLOG_PATH='/home/postgres/arch' --归档目录

SRVLOG_PATH='/home/postgres/data/log' --数据库错误日志目录

COMPRESS_DATA = YES --压缩数据

KEEP_ARCLOG_FILES = 10 --保存归档文件个数

KEEP_ARCLOG_DAYS = 10 --保存归档的天数

KEEP_DATA_GENERATIONS = 3 --备份冗余度

KEEP_DATA_DAYS = 10 --保存备份集时间

KEEP_SRVLOG_FILES = 10 --保存日志文件个数

KEEP_SRVLOG_DAYS = 10 --保存日志文件天数

 

自动维护操作

在进行备份操作时会自动检查:

pg_rman backup --backup-mode=full

INFO: start deleting old archived WAL files from ARCLOG_PATH (keep files = 10, keep days = 10)

INFO: the threshold timestamp calculated by keep days is "2022-11-06 00:00:00"

 

INFO: start deleting old backup (keep generations = 3 AND keep after = 2022-11-06 00:00:00)

 

CUUG PostgreSQL技术大讲堂系列公开课第42讲-pg_rman部署与使用,往期视频及文档,请联系CUUG。

标签:11,PostgreSQL,21,备份,42,pg,2022,rman
From: https://www.cnblogs.com/cnblogs5359/p/17974464

相关文章

  • Docker安装PostgreSQL
    Tips:内容仅供参考。保证联网[root@node1/etc/yum.repos.d]#dockersearchpostgres[root@node1/etc/yum.repos.d]#dockerpullpostgres:14.2创建Docker挂载目录[root@node1/etc/yum.repos.d]#mkdir/data/postgresql-p运行一个新PostgreSQL容器dockerrun--namepostgres--......
  • 离线安装PostgreSQL
    Tips:内容仅供参考1.1先安装库文件,其次安装客户端,最后安装服务端rpm-ivhpostgresql12-libs-12.15-1PGDG.rhel7.x86_64.rpmrpm-ivhpostgresql12-12.15-1PGDG.rhel7.x86_64.rpmrpm-ivhpostgresql12-server-12.15-1PGDG.rhel7.x86_64.rpmTips:安装完服务端软件自动创建postgres......
  • 清醒时刻记 42
    我虽然看过了《繁花》的电视剧,但是没看过繁华的书,网评都在说其实跟原著书籍里的还是有较大的区别的,可能是因为导演太个性,而演员又都是个性鲜明所致.不仅是这些演员,就连现在各个网络视频平台上的叫得上号的博主,都是走各自独特的路线的,这也就是经济学里所说的细分市场了,人......
  • 为什么机器学习习惯设置random_state = 42 ?
    在学机器学习写代码时一直有个小疑问,为什么大家习惯设置random_state=42?甚至许多官方文档也是用的42这个数字。简单上网搜索之后发现原来是在致敬这本道格拉斯·亚当斯所作的幽默荒诞风的科幻小说——《银河系漫游指南》(Thehitchhiker'sguidetothegalaxy)花了两天时间把这本......
  • PostgreSQL安装部署
    1.使用yum安装1)安装数据库服务器yuminstall-yhttps://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpmyuminstall-ypostgresql15-server2)初始化并启动数据库/usr/pgsql-15/bin/postgresql-15-setupinitdb#默认......
  • P5642 人造感情
    P5642人造感情首先考虑如何求\(W(U)\)。对于路径\((x,y,w)\),我们将它挂在\(u=lca(x,y)\)上,记\(f_u\)表示仅考虑\(u\)子树内的链获得的最大值,\(s_u=\sum_{v\inson_u}f_v\),表示仅考虑\(u\)子树内的链,且钦定\(u\)不被占用的最大值。\(s_u\)易求,若\(u\)不被占用,\(......
  • 开发遇到的问题总结---mysql建表报SQL 错误 [1067] [42000]: Invalid default value f
    报错内容:SQL错误[1067][42000]:Invaliddefaultvaluefor'begin_time'sql语句:CREATETABLE`tb_seckill_voucher`(`voucher_id`bigint(20)UNSIGNEDNOTNULLCOMMENT'关联的优惠券的id',`stock`int(8)NOTNULLCOMMENT'库存',`creat......
  • 42 干货系列从零用Rust编写负载均衡及代理,wmproxy中配置tcp转websocket
    wmproxywmproxy已用Rust实现http/https代理,socks5代理,反向代理,静态文件服务器,四层TCP/UDP转发,七层负载均衡,内网穿透,后续将实现websocket代理等,会将实现过程分享出来,感兴趣的可以一起造个轮子项目地址国内:https://gitee.com/tickbh/wmproxygithub:https://github.com/......
  • PostgreSQL 临时表
    CREATETEMPTABLE这种方式创建的临时表默认是session级别的,session关闭会自动删除。(也可以创建为事务级别的,事务结束自动删除)。 CREATETEMPTABLEtemp_table_name(column_list);postgresql官方文档介绍:临时表存在于一个特殊的schema里,所以不支持创建的时候指定sch......
  • P7424 [THUPC2017] 天天爱射击
    [THUPC2017]天天爱射击题目描述小C爱上了一款名字叫做《天天爱射击》的游戏。如图所示,这个游戏有一些平行于\(x\)轴的木板。现在有一些子弹,按顺序沿着\(y\)轴方向向这些木板射去。第\(i\)块木板被\(S_i\)个子弹贯穿以后,就会碎掉消失。一个子弹可以贯穿其弹道上的全部......