POSTGRESQL9.5之pg_rman工具
pg_rman是一款专门为postgresql设计的在线备份恢复的工具。其支持在线和基于时间点备份方式,还可以通过创建backup catalog来维护DB cluster备份信息。
看起来好像是模仿oracle的RMAN工具。
pg_rman特点:
- 使用简单.一个命令即可完成备份和恢复.
- 支持在线全备,增量备份,归档备份.
- 支持备份压缩.通过gzip工具实现页内压缩.
- 自动备份维护.自动删除过期的WAL备份文件.
- 支持备份验证.
- 恢复期间无事务丢失.支持基于PITR的配置文件生成器.
包:pg_rman-1.3.2-1.pg95.rhel6.x86_64.rpm
[root@sdserver40_210 software]# rpm -ivh postgresql95-libs--1PGDG.rhel6.x86_64.rpm warning: postgresql95-libs--1PGDG.rhel6.x86_64.rpm: Header V4 DSA/SHA1 Signature, key ID 442df0f8: NOKEY Preparing... ########################################### [%] :postgresql95-libs ########################################### [%] [root@sdserver40_210 software]# rpm -ivh pg_rman--.pg95.rhel6.x86_64.rpm Preparing... ########################################### [%] :pg_rman ########################################### [%]
2. 配置环境变量
3.初始化备份目录
[postgres@sdserver40_210 ~]$ pg_rman init -B /data/pg_rman INFO: ARCLOG_PATH is set to '/home/postgres/archive' INFO: SRVLOG_PATH is set to '/data/pgdata/pg_log'
[postgres@sdserver40_210 ~]$ pg_rman backup --backup-mode=full --progress INFO: copying database files Processed of files, skipped NOTICE: pg_stop_backup complete, all required WAL segments have been archived INFO: copying archived WAL files Processed of files, skipped INFO: backup complete HINT: Please execute 'pg_rman validate' to verify the files are correctly copied.
--pg_rman 的备份必须都是经过验证过的,否则不能进行恢复和增量备份
Backups without validation cannot be used forrestoreand incremental backup--执行完备份要执行一次validate,因为备份后的状态是done,还不能进行恢复
[postgres@sdserver40_210 ~]$ pg_rman show ========================================================== StartTime Mode Duration Size TLI Status ========================================================== -- :: FULL 0m 343MB DONE [postgres@sdserver40_210 ~]$ pg_rman validate INFO: validate: "2016-05-31 16:36:45" backup and archive log files by CRC INFO: backup "2016-05-31 16:36:45" is valid [postgres@sdserver40_210 ~]$ pg_rman show ========================================================== StartTime Mode Duration Size TLI Status ========================================================== -- :: FULL 0m 343MB OK
[postgres@sdserver40_210 ~]$ ll total drwxrwxr-x postgres postgres May : archive drwxrwxr-x postgres postgres May : backup drwx------ postgres postgres May : data drwxrwxr-x postgres postgres May : log -rw-rw-r-- postgres postgres May : out_file -rw-rw-r-- postgres postgres May : out.txt drwxrwxr-x postgres postgres May : scripts -rw-r--r-- postgres postgres May : test.sql [postgres@sdserver40_210 ~]$ rm -rf data [postgres@sdserver40_210 ~]$ ll total drwxrwxr-x postgres postgres May : archive drwxrwxr-x postgres postgres May : backup drwxrwxr-x postgres postgres May : log -rw-rw-r-- postgres postgres May : out_file -rw-rw-r-- postgres postgres May : out.txt drwxrwxr-x postgres postgres May : scripts -rw-r--r-- postgres postgres May : test.sql [postgres@sdserver40_210 ~]$ pg_stop waiting for server to shut down.... done server stopped [postgres@sdserver40_210 ~]$ pg_rman restore --recovery-target-time "2016-05-31 17:30:00" INFO: the recovery target timeline ID is not given INFO: use timeline ID of current database cluster INFO: calculating timeline branches to be used to recovery target point INFO: searching latest full backup which can be used as restore start point INFO: found the full backup can be used as base in recovery: "2016-05-31 16:36:45" INFO: copying online WAL files and server log files INFO: clearing restore destination INFO: validate: "2016-05-31 16:36:45" backup and archive log files by SIZE INFO: backup "2016-05-31 16:36:45" is valid INFO: restoring database files from the full mode backup "2016-05-31 16:36:45" INFO: searching incremental backup to be restored INFO: searching backup which contained archived WAL files to be restored INFO: backup "2016-05-31 16:36:45" is valid INFO: restoring WAL files from backup "2016-05-31 16:36:45" INFO: restoring online WAL files and server log files INFO: generating recovery.conf INFO: restore complete HINT: Recovery will start automatically when the PostgreSQL server is started. [postgres@sdserver40_210 ~]$ pg_start server starting [postgres@sdserver40_210 ~]$ psql mydb lottu psql () Type "help" for help. mydb=> \d List of relations Schema | Name | Type | Owner --------+------+-------+------- public | test | table | lottu ( row) mydb=> select * from test; id | name ------+-------- | lottu | rax | xuan | li0924 ( rows) mydb=> \q [postgres@sdserver40_210 ~]$ ll total drwxrwxr-x postgres postgres May : archive drwxrwxr-x postgres postgres May : backup drwx------ postgres postgres May : data drwxrwxr-x postgres postgres May : log -rw-rw-r-- postgres postgres May : out_file -rw-rw-r-- postgres postgres May : out.txt drwxrwxr-x postgres postgres May : scripts -rw-r--r-- postgres postgres May : test.sql
【参考文献】
POSTGRESQL9.5之pg_rman工具的更多相关文章
- PostgreSQL配置优化
硬件和系统配置 操作系统 Ubuntu13.04 系统位数 64 CPU Intel(R) Core(TM)2 Duo CPU 内存 4G 硬盘 Seagate ST2000DM001-1CH164 ...
- windows下源码安装调试postgresql
环境:windows 10 postgresql版本:postgresql-9.6.5 使用工具:vs2017社区版 辅助工具:perl.diff.flex.bison 相关工具下载地址: perl下 ...
- PostgreSQL 优势,MySQL 数据库自身的特性并不十分丰富,触发器和存储过程的支持较弱,Greenplum、AWS 的 Redshift 等都是基于 PostgreSQL 开发的
PostgreSQL 优势 2016-10-20 21:36 686人阅读 评论(0) 收藏 举报 分类: MYSQL数据库(5) PostgreSQL 是一个自由的对象-关系数据库服务器(数据库 ...
- 调试postgresql9.5.2最新源码
最近在考量数据库的选型,考虑后期把数据切换到postgresql ,postgresql源码用c实现,代码很精炼完美,值得学习下 首先去pgsql官网下载最新的源码 ,然后还需要perl,bison ...
- 基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版)
目录: 第1版:http://blog.csdn.net/vipbooks/article/details/51912143 第2版:htt ...
- 使用pg_upgrade工具为PostgreSQL进行版本升级
公司的测试环境和生产环境都是9.2.4版本,而开发环境是9.0.18版本. PS: 不知道公司里的其它同事,是如何做数据库迁移的,利用第三方可视化工具备份数据库,然后恢复到其它高版本的环境?反正我没成 ...
- linux下Postgresql-9.2安装及数据库的创建过程
公司写部署手册需要,现总结一些linux下postgresql的安装及数据库创建的详细步骤吧! 1.1.1 软件安装 1.设置用户组和用户级别 Postgresql不能以root身份运行,要以其 ...
- PostgreSQL 使用PG_Rman进行物理备份
背景 在Oracle下我们可以使用rman进行物理备份,支持数据库的全量.增量.归档的备份模式而PostgreSQL作为开源数据库,近些时间来也一直向商业版数据库看齐,也推出了开源功工具pg_rman ...
- win7 编译postgresql9.6.8
一.环境 windows7 postgresql9.6.8 vs2010 perl5.24.3 二.编译安装 1.安装perl,安装到C:\Perl64路径下,安装完成后设置环境变量PATH和Perl ...
随机推荐
- 教你安装CentOS 6.5如何选择安装包
近来发现越来越多的运维小伙伴们都有最小化安装CentOS 6.5系统的洁癖,因此,找老男孩来咨询,这个“洁癖”好习惯啊,必须支持,,因此发布本文和大家分享下. (1)系统安装类型选择及自定义额外包组 ...
- C# web api 返回类型设置为json的两种方法
每次写博客,第一句话都是这样的:程序员很苦逼,除了会写程序,还得会写博客!当然,希望将来的一天,某位老板看到此博客,给你的程序员职工加点薪资吧!因为程序员的世界除了苦逼就是沉默.我眼中的程序员大多都不 ...
- css 字数超过一行显示省略号
display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
- 评估指标:准确率(Precision)、召回率(Recall)以及F值(F-Measure)
为了能够更好的评价IR系统的性能,IR有一套完整的评价体系,通过评价体系可以了解不同信息系统的优劣,不同检索模型的特点,不同因素对信息检索的影响,从而对信息检索进一步优化. 由于IR的目标是在较短时间 ...
- ImportError: No module named setuptools
Python第三方模块中一般会自带setup.py文件,在Windows环境下,我们只需要使用命令 cd c:\Temp\foo python setup.py install 两个命令就可以完成第三 ...
- editplus3运行Python程序
editplus3是一款不错的编辑器,他可以编译,运行java,php等各种程序,现把他运行Python程序的方法贴出来,首先得安装python,然后打开editplug3,工具——配置用户工具——组 ...
- OLTP与OLAP的差异
OLTP与OLAP的差异 系统类型 OLTP(在线交易系统) OLAP(联机分析系统),DW(数据仓库) 数据来源 操作数据,OLTP通常是原始性数据源 联合型数据:OLAP数据来源于其他OLTP系统 ...
- 转:windows 7系统安装与配置Tomcat服务器环境
工具/原料 jdk-7u45-windows-x64(我的系统是64位系统,32位的请选x86下载) apache-tomcat-8.0.0-RC5-windows-x64 方法/步骤 下载说明, ...
- Windows7 IIS7.5 HTTP Error 503 The service is unavailable 另类解决方案
这篇文章是在你看了别的解决方案仍然解决不了之后才有用. 所以再未用别的解决方案之前,用了该解决方案依然无效的话,请自己看着办. 原创: .net2.0和.net3.5的应用程序池请在开始菜单打开VS2 ...
- paper 43 :ENDNOTE下载及使用方法简介
转载来源:http://blog.sciencenet.cn/blog-484734-367968.html 软件下载来源: EndNote v9.0 Final 正式版:http://www.ttd ...