热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

Postgresql数据库如何做联机热备

Postgresql同样支持在线备份,该备份方式与oracle中用户热备的方式相同,手动拷贝数据文库文件与归档日志。可以根据测试过程将备份直接写成script,通过定制,完成数据库的自动备份。postgresql的恢复支持基于时间戳与事务ID,可以通过时间戳或事务ID的方式,完成

Postgresql同样支持在线备份,该备份方式与oracle中用户热备的方式相同,手动拷贝数据文库文件与归档日志。可以根据测试过程将备份直接写成script,通过定制,完成数据库的自动备份。

  postgresql的恢复支持基于时间戳与事务ID,可以通过时间戳或事务ID的方式,完成数据库的不完全恢复或者因错误操作的故障恢复。

  该测试目的:postgresql的在线备份;通过在线备份完成恢复。

  1,开启归档

 

  [postgre@daduxiong ~]$ more /usr/local/pgsql/data/postgresql.conf |grep archive_ 
archive_mode on               allows archiving to be done 
archive_command 'cp -i %p /archive/%f >/dev/null'

 

  2,重新启动数据库

 

[root@daduxiong ~]# service postgresql stop 
Stopping PostgreSQL: server stopped 
ok 
[root@daduxiong ~]# service postgresql start 
Starting PostgreSQL: ok

 

  3,启动备份

 

[postgre@daduxiong archive]$ psql postgres -c "select pg_start_backup('hot_backup');"  
 pg_start_backup  
----------------- 
 0/7000020 
(1 row)

 

  4,使用tar命令备份数据库文件,不包含pg_xlog目录


[postgre@daduxiong archive]$ tar --exclude $PGDATA/pg_xlog -cvjpf /archive/pgbackup.tar.bz2 $PGDATA

 

  5,完成备份


[postgre@daduxiong archive]$ psql postgres -c "select pg_stop_backup();" pg_stop_backup ---------------- 0/70133A0(1 row)

 

  6,在postgres数据库中创建表并插入记录,作为恢复时的判断。

 

[postgre@daduxiong archive]$ psql postgres 
Welcome to psql 8.3.10, the PostgreSQL interactive terminal. 

Type:  \copyright for distribution terms 
       \h for help with SQL commands 
       \? for help with psql commands 
       \g or terminate with semicolon to execute query 
       \q to quit 

postgres=# create table abc(id integer); 
CREATE TABLE 
postgres=# insert into abc values(1); 
INSERT 
postgres=# \q

 

  7,此时假设数据库出现问题,停止数据库,拷贝日志

 

[root@daduxiong pgsql]# service postgresql stop 
Stopping PostgreSQL: server stopped 
ok 
[postgre@daduxiong archive]$ cp $PGDATA/pg_xlog/*00* /archive/

 

  8,删除"发生错误"的data目录

 

[root@daduxiong pgsql]# rm -rf data

 

  9,解压之前的备份文件压缩包

 

[postgre@daduxiong pgsql]$ tar -xvf /archive/pgbackup.tar.bz2 
....省略 
/usr/local/pgsql/data/global/2843 
/usr/local/pgsql/data/postmaster.opts 
/usr/local/pgsql/data/pg_twophase/ 
/usr/local/pgsql/data/postmaster.pid 
/usr/local/pgsql/data/backup_label 
/usr/local/pgsql/data/PG_VERSION

 

  10,恢复data目录,重新创建pg_xlog目录及其子目录archive_status

 

[root@daduxiong pgsql]# mv /archive/usr/local/pgsql/data /usr/local/pgsql 
[root@daduxiong data]# mkdir pg_xlog 
[root@daduxiong data]# chmod 0700 pg_xlog/ 
[root@daduxiong data]# chown postgre:postgre pg_xlog/ 
[root@daduxiong data]# cd pg_xlog/ 
[root@daduxiong pg_xlog]# mkdir archive_status 
[root@daduxiong pg_xlog]# chmod 0700 archive_status/ 
[root@daduxiong pg_xlog]# chown postgre:postgre archive_status/ 
[root@daduxiong pg_xlog]# mv /archive/*00* /usr/local/pgsql/data/pg_xlog 
[root@daduxiong pg_xlog]# cd .. 
[root@daduxiong data]# ls 
backup_label  pg_clog        pg_multixact  pg_twophase  postgresql.conf 
base          pg_hba.conf    pg_subtrans   PG_VERSION   postmaster.opts 
global        pg_ident.conf  pg_tblspc     pg_xlog      postmaster.pid

 

  11,配置恢复配置文件


[root@daduxiong data]# touch recovery.conf 
[root@daduxiong data]# echo "restore_command='cp -i /archive/%f %p'" >>recovery.conf 
[root@daduxiong data]# chown postgre:postgre recovery.conf 
[root@daduxiong data]# chmod 0750 recovery.conf

 

  12,启动数据库,观察数据库启动的日志


[root@daduxiong data]# service postgresql start 
Starting PostgreSQL: ok 

---省略日志部分内容 
LOG:  selected new timeline ID: 
LOG:  restored log file "00000002.history" from archive 
LOG:  archive recovery complete 
LOG:  autovacuum launcher started 
LOG:  database system is ready to accept connections

 

  13,验证恢复结果。检查之前创建的表与记录。


[postgre@daduxiong archive]$ psql postgres 
Welcome to psql 8.3.10, the PostgreSQL interactive terminal. 

Type:  \copyright for distribution terms 
       \h for help with SQL commands 
       \? for help with psql commands 
       \g or terminate with semicolon to execute query 
       \q to quit 

postgres=# select from abc; 
 id 
---- 
  
(1 row) 

postgres=# \q 

[root@daduxiong data]# ls -l 
total 80 
-rw------- postgre postgre   147 Aug 31 10:26 backup_label.old 
drwx------ postgre postgre  4096 Aug 27 11:33 base 
drwx------ postgre postgre  4096 Aug 31 10:41 global 
drwx------ postgre postgre  4096 Aug 10 11:06 pg_clog 
-rwx------ postgre postgre  3429 Aug 10 11:10 pg_hba.conf 
-rwx------ postgre postgre  1460 Aug 10 11:06 pg_ident.conf 
drwx------ postgre postgre  4096 Aug 10 11:06 pg_multixact 
drwx------ postgre postgre  4096 Aug 10 11:06 pg_subtrans 
drwx------ postgre postgre  4096 Aug 10 11:06 pg_tblspc 
drwx------ postgre postgre  4096 Aug 10 11:06 pg_twophase 
-rwx------ postgre postgre     Aug 10 11:06 PG_VERSION 
drwx------ postgre postgre  4096 Aug 31 10:35 pg_xlog 
-rwx------ postgre postgre 16727 Aug 31 09:42 postgresql.conf 
-rwx------ postgre postgre    59 Aug 31 10:35 postmaster.opts 
-rw------- postgre postgre    47 Aug 31 10:35 postmaster.pid 
-rwxr-x--- postgre postgre    39 Aug 31 10:34 recovery.done

 

  说明:

  该测试中采用的是系统安装默认的数据,如果是生产库需要注意备份所有的表空间,不能仅仅备份软连接.

  数据库完成备份后,recovery.conf文件变成recovery.done,backup_label文件变成了backup_lable.old.

  oracle的备份通常采用RMAN工具备份,该工具功能强大,使用方便,得到大家的认可。

  开源项目组也为postgresql开发了一款类似的工具pg-rman,其功能也很强大,使用方式和特点与ORACLE的RMAN非常类似。


推荐阅读
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • 本文详细介绍了在ASP.NET中获取插入记录的ID的几种方法,包括使用SCOPE_IDENTITY()和IDENT_CURRENT()函数,以及通过ExecuteReader方法执行SQL语句获取ID的步骤。同时,还提供了使用这些方法的示例代码和注意事项。对于需要获取表中最后一个插入操作所产生的ID或马上使用刚插入的新记录ID的开发者来说,本文提供了一些有用的技巧和建议。 ... [详细]
  • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
  • 如何去除Win7快捷方式的箭头
    本文介绍了如何去除Win7快捷方式的箭头的方法,通过生成一个透明的ico图标并将其命名为Empty.ico,将图标复制到windows目录下,并导入注册表,即可去除箭头。这样做可以改善默认快捷方式的外观,提升桌面整洁度。 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • 本文介绍了在Win10上安装WinPythonHadoop的详细步骤,包括安装Python环境、安装JDK8、安装pyspark、安装Hadoop和Spark、设置环境变量、下载winutils.exe等。同时提醒注意Hadoop版本与pyspark版本的一致性,并建议重启电脑以确保安装成功。 ... [详细]
  • 使用在线工具jsonschema2pojo根据json生成java对象
    本文介绍了使用在线工具jsonschema2pojo根据json生成java对象的方法。通过该工具,用户只需将json字符串复制到输入框中,即可自动将其转换成java对象。该工具还能解析列表式的json数据,并将嵌套在内层的对象也解析出来。本文以请求github的api为例,展示了使用该工具的步骤和效果。 ... [详细]
  • HDFS2.x新特性
    一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
  • 仙贝旅行是日本最大的旅游服务平台之一,为广大用户提供优质的日本定制游服务。随着用户数量的增长,仙贝旅行决定与智齿科技合作,全面替换原有客服系统,打造全新的在线客服体系。该体系具备多渠道快速接入的能力,让仙贝旅行轻松与各个渠道的接入用户完成沟通。同时,机器人与人工协同发力,提升客户服务水平。 ... [详细]
  • 本文介绍了一些Java开发项目管理工具及其配置教程,包括团队协同工具worktil,版本管理工具GitLab,自动化构建工具Jenkins,项目管理工具Maven和Maven私服Nexus,以及Mybatis的安装和代码自动生成工具。提供了相关链接供读者参考。 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了StartingzookeeperFAILEDTOSTART相关的知识,希望对你有一定的参考价值。下载路径:https://ar ... [详细]
  • 本文介绍了在Linux下安装和配置Kafka的方法,包括安装JDK、下载和解压Kafka、配置Kafka的参数,以及配置Kafka的日志目录、服务器IP和日志存放路径等。同时还提供了单机配置部署的方法和zookeeper地址和端口的配置。通过实操成功的案例,帮助读者快速完成Kafka的安装和配置。 ... [详细]
  • SAP羞辱国产软件商:技术停在10年前
    SAP中国研究院总裁芮祥麟表示,国产软件厂商过于热衷概念炒作,技术水平停留在10年前的客户端架构水平。他认为,国内厂商推出基于SOA的产品或转型SAAS模式是不可能的,研发新架构需要时间。当前最热门的概念是云计算,芮祥麟呼吁国产厂商应该潜心研发底层架构。 ... [详细]
  • IT方面的论坛太多了,有综合,有专业,有行业,在各个论坛里混了几年,体会颇深,以前是论坛哪里人多 ... [详细]
  • CEPH LIO iSCSI Gateway及其使用参考文档
    本文介绍了CEPH LIO iSCSI Gateway以及使用该网关的参考文档,包括Ceph Block Device、CEPH ISCSI GATEWAY、USING AN ISCSI GATEWAY等。同时提供了多个参考链接,详细介绍了CEPH LIO iSCSI Gateway的配置和使用方法。 ... [详细]
author-avatar
吴姿云68153
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有