PostgreSQL 没有类似MySQL 的二进制日志, 但是有和MySQL 类似的REDO LOG,并且有MySQL 没有的REDO 归档功能。当然REDO 的归档已经MariaDB 和Percona-MySQL 已经实现。

那我们就利用PGSQL的REDO 归档,也叫WAL来实现增量备份。

假设我们已经做了一个物理的全备,并且相应的参数都已经设置完毕,比如以下:

  1.  
    /home/full_backup 保存全备的目录。
  2.  
    /home/increment_log 保存增备的目录。
  3.  
     
  4.  
     
  5.  
    进入postgresql.conf
  6.  
    开启WAL.
  7.  
    wal_level = archive
  8.  
    wal_keep_segments=1
  9.  
    开启WAL 的归档模式.
  10.  
    archive_mode = on
  11.  
    archive_command = 'test ! -f /home/increment_log/%f && cp %p /home/increment_log/%f' (归档,也就是增量)

那么关于WAL归档日志要注意的一点是,如果CRASH 掉了,那么没有归档的XLOG也可能没有提交到数据文件,所以有可能这部分数据会丢失掉。所以在之后恢复的时候我们要把这部分XLOG拷贝到全备的对应目录。

恢复方法:

  1.  
    1. 确保没有任何业务对PG服务进行访问。(有可能这个时候PG已经CRASH掉了。)
  2.  
    2. 先停掉POSTGRESQL 服务。
  3.  
    3. cd /home/pgsql;
  4.  
    4. mv data data_old
  5.  
    6. cp -rfp /home/full_backup/* /home/pgsql (拷贝全备)
  6.  
    7. cp -rfp data_old/pg_xlog/000* data/pg_xlog/ (这里是拷贝自从最后一个增量和系统CRASH之间的XLOG到对应的目录。)
  7.  
    8. cd data
  8.  
    9. vi recovery.conf (添加recovery.conf文件,让PG认为这次是在恢复。)
  9.  
    restore_command='test ! -f /home/increment_log/%f && cp /home/increment_log/%f %p'
  10.  
    recovery_target_timeline = 'latest'
  11.  
    10. chown -R postgres.postgres recovery.conf
  12.  
    11. 启动postgresql 服务即可。

如果正确恢复了,那么recovery.conf 会自动更名为recovery.done.

以我的机器为例,我的版本是9.3,PG_XLOG中看到的BACKUP 信息:

  1.  
    [root@postgresql-instance pg_xlog]# cat 000000010000000000000003.00000028.backup
  2.  
    START WAL LOCATION: 0/3000028 (file 000000010000000000000003)
  3.  
    STOP WAL LOCATION: 0/30000B8 (file 000000010000000000000003)
  4.  
    CHECKPOINT LOCATION: 0/3000028
  5.  
    BACKUP METHOD: pg_start_backup
  6.  
    BACKUP FROM: master
  7.  
    START TIME: 2014-01-07 03:35:02 EST
  8.  
    LABEL: ytt
  9.  
    STOP TIME: 2014-01-07 03:36:27 EST

日志中会看到恢复如下恢复信息:

    1.  
      < 2014-01-07 05:02:47.361 EST >LOG: 00000: starting archive recovery
    2.  
      < 2014-01-07 05:02:47.361 EST >LOCATION: StartupXLOG, xlog.c:4983
    3.  
      < 2014-01-07 05:02:47.369 EST >LOG: 00000: redo starts at 0/3000028
    4.  
      < 2014-01-07 05:02:47.369 EST >LOCATION: StartupXLOG, xlog.c:5531
    5.  
      < 2014-01-07 05:02:47.371 EST >LOG: 00000: consistent recovery state reached at 0/303FC88

PostgreSQL 增量备份详解以及相关示例的更多相关文章

  1. mysql全量和增量备份详解(带脚本)

    在日常运维工作中,对mysql数据库的备份是万分重要的,以防在数据库表丢失或损坏情况出现,可以及时恢复数据. 下面对这种备份方案详细说明下:1.MySQLdump增量备份配置执行增量备份的前提条件是M ...

  2. Xtrabackup全量 增量备份详解

    xtrabackup是Percona公司CTO Vadim参与开发的一款基于InnoDB的在线热备工具,具有开源,免费,支持在线热备,备份恢复速度快,占用磁盘空间小等特点,并且支持不同情况下的多种备份 ...

  3. MySQL系列详解五: xtrabackup实现完全备份及增量备份详解-技术流ken

    xtrabackup简介 xtrabackup是一个用来对mysql做备份的工具,它可以对innodb引擎的数据库做热备.xtrabackup备份和还原速度快,备份操作不会中断正在执行的事务,备份完成 ...

  4. Linux lsof命令详解和使用示例【转】

    所以如传输控制协议 (TCP) 和用户数据报协议 (UDP) 套接字等,系统在后台都为该应用程序分配了一个文件描述符,无论这个文件的本质如何,该文件描述符为应用程序与基础操作系统之间的交互提供了通用接 ...

  5. MySQL数据库备份详解

    原文:MySQL数据库备份详解 对于任何数据库来说,备份都是非常重要的 数据库复制不能取代备份的作用 比如我们由于误操作,在主数据库上删除了一些数据,由于主从复制的时间很短,在发现时,从数据库上的数据 ...

  6. slf4j log4j logback关系详解和相关用法

    slf4j log4j logback关系详解和相关用法 写java也有一段时间了,一直都有用slf4j log4j输出日志的习惯.但是始终都是抱着"拿来主义"的态度,复制粘贴下配 ...

  7. WebService核心文件【server-config.wsdd】详解及调用示例

    WebService核心文件[server-config.wsdd]详解及调用示例 作者:Vashon 一.准备工作 导入需要的jar包: 二.配置web.xml 在web工程的web.xml中添加如 ...

  8. slf4j log4j logback log4j2关系详解和相关用法

    来源:slf4j log4j logback关系详解和相关用法https://www.cnblogs.com/Sinte-Beuve/p/5758971.html The Simple Logging ...

  9. php为什么需要异步编程?php异步编程的详解(附示例)

    本篇文章给大家带来的内容是关于php为什么需要异步编程?php异步编程的详解(附示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 我对 php 异步的知识还比较混乱,写这篇是为了 ...

随机推荐

  1. SQL月度统计

    select Convert ( VARCHAR(7),CreateTime,120) as Date ,sum(Money) as M FROM [LBAmmeterDB].[dbo].Am_Tas ...

  2. [ipsec][strongswan] strongswan源码分析--(五)plugin的配置文件的添加方法与管理架构解析

    前言 我们知道,strongswan是基于插件式管理的.不同的插件有不同的配置文件,在这下面, 我们以netlink的插件为例:etc/strongswan.d/charon/kernel-netli ...

  3. Django admin 页面中文名称加s,去除s的设置

    class UserInfo(models.Model): #字段 #字段 #字段 class Meta: verbose_name_plural = '用户列表'

  4. css定位基础知识

    标题:css定位 地址:https://www.w3school.com.cn/css/css_positioning.asp

  5. P1345 [USACO5.4]奶牛的电信[拆点+最小割]

    题目描述 农夫约翰的奶牛们喜欢通过电邮保持联系,于是她们建立了一个奶牛电脑网络,以便互相交流.这些机器用如下的方式发送电邮:如果存在一个由c台电脑组成的序列a1,a2,...,a(c),且a1与a2相 ...

  6. 《少年先疯队》第八次团队作业:Alpha冲刺第一天

    前言   第一天冲刺会议   时间:2019.6.14   地点:9C406 1.1 今日完成任务情况以及遇到的问题.   1.1.1今日完成任务情况 姚玉婷:管理员登录功能的实现,用户登录功能的实现 ...

  7. Oracle 序号函数

    Oracle提供的序号函数:以emp表为例:1: rownum 最简单的序号 但是在order by之前就确定值.select rownum,t.* from emp t order by ename ...

  8. 国产MM才叫漂亮[景甜]

  9. UVA 11468 Substring (记忆化搜索 + AC自动鸡)

    传送门 题意: 给你K个模式串, 然后,再给你 n 个字符, 和它们出现的概率 p[ i ], 模式串肯定由给定的字符组成. 且所有字符,要么是数字,要么是大小写字母. 问你生成一个长度为L的串,不包 ...

  10. codevs 5958 无

    5958 无  时间限制: 1 s  空间限制: 1000 KB  题目等级 : 大师 Master 题解       题目描述 Description 无 输入描述 Input Descriptio ...