设为首页 加入收藏

TOP

PostgreSQL增量备份详解以及相关示例
2014-11-24 07:22:25 来源: 作者: 【 】 浏览:2
Tags:PostgreSQL 增量 备份 详解 以及 相关 示例
PostgreSQL 没有类似MySQL 的二进制日志, 但是有和MySQL 类似的REDO LOG,并且有MySQL 没有的REDO 归档功能。当然REDO 的归档已经MariaDB 和Percona-MySQL 已经实现。
那我们就利用PGSQL的REDO 归档,也叫WAL来实现增量备份。

/home/full_backup 保存全备的目录。 /home/increment_log 保存增备的目录。 进入postgresql.conf 开启WAL. wal_level = archive wal_keep_segments=1 开启WAL 的归档模式. archive_mode = on archive_command = 'test ! -f /home/increment_log/%f && cp %p /home/increment_log/%f' (归档,也就是增量)
1. 确保没有任何业务对PG服务进行访问。(有可能这个时候PG已经CRASH掉了。) 2. 先停掉POSTGRESQL 服务。 3. cd /home/pgsql; 4. mv data data_old 6. cp -rfp /home/full_backup/* /home/pgsql (拷贝全备) 7. cp -rfp data_old/pg_xlog/000* data/pg_xlog/ (这里是拷贝自从最后一个增量和系统CRASH之间的XLOG到对应的目录。) 8. cd data 9. vi recovery.conf (添加recovery.conf文件,让PG认为这次是在恢复。) restore_command='test ! -f /home/increment_log/%f && cp /home/increment_log/%f %p' recovery_target_timeline = 'latest' 10. chown -R postgres.postgres recovery.conf 11. 启动postgresql 服务即可。
[root@postgresql-instance pg_xlog]# cat 000000010000000000000003.00000028.backup START WAL LOCATION: 0/3000028 (file 000000010000000000000003) STOP WAL LOCATION: 0/30000B8 (file 000000010000000000000003) CHECKPOINT LOCATION: 0/3000028 BACKUP METHOD: pg_start_backup BACKUP FROM: master START TIME: 2014-01-07 03:35:02 EST LABEL: ytt STOP TIME: 2014-01-07 03:36:27 EST
< 2014-01-07 05:02:47.361 EST >LOG: 00000: starting archive recovery < 2014-01-07 05:02:47.361 EST >LOCATION: StartupXLOG, xlog.c:4983 < 2014-01-07 05:02:47.369 EST >LOG: 00000: redo starts at 0/3000028 < 2014-01-07 05:02:47.369 EST >LOCATION: StartupXLOG, xlog.c:5531 < 2014-01-07 05:02:47.371 EST >LOG: 00000: consistent recovery state reached at 0/303FC88
 
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇SQLServer2012AlwaysOnGroup使用I.. 下一篇PostgreSQL配置优化

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·Java 并发工具类:提 (2025-12-25 20:25:44)
·Java面试技巧:如何 (2025-12-25 20:25:41)
·Java并发编程中的线 (2025-12-25 20:25:38)
·C 语言 - cppreferen (2025-12-25 19:50:27)
·《C 语言入门教程》 (2025-12-25 19:50:23)