恢复postgresql数据库的方法

介绍

这篇文章将为大家详细讲解有关恢复postgresql数据库的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

postgresql的备份分为三种:

SQL转储

文件系统级别备份(冷备份)

在线热备份(归档)

以下通过实例来讲解postgresql的三种备份。

二、SQL转储

(一)pg_dump

1,创建数据库

createdb pg

2,连入数据库pg

psql pg

3,创建测试表,插入数据

pg=#创建表pg_test (int);

pg=#插入pg_test (1) (a)值;

pg=#插入pg_test (2) (a)值;

4,查看数据

pg=# select * from结核病;

(2行)

5,备份

pg_dump pg祝辞/usr/local/pgsql/backup/pg.dmp

6,删除数据库pg dropdb pg

7日创建新数据库(恢复之前需创建数据库)

createdb pg

8日恢复数据

psql pb & lt;/usr/local/pgsql/backup/pg.dmp

9日查看数据是否回复

pg=# select * from结核病;

(2行)

至此,数据已成功恢复!

注:pg_dump可以对针对单表或者多表进行备份

如:pg_dump数据库名- t tablename1 - t tablename2祝辞文件名

(二)pg_dumpall

pg_dump只能备份单个数据库,而且恢复的时候需要创建空数据库.pg_dumpall可以备份所有数据库,并且备份角色,表空间。

1,创建数据库

createdb pg1

createdb pg2

2, pg1中创建表并插入数据

psql pg1

pg=#创建表tb1 (int)

pg=#插入tb1 (1) (a)值;

3, pg2中创建表并插入数据

psql pg2

pg=#创建表tb2 (int)

pg=#插入tb2 (2) (a)值;

4,备份数据库

pg_dumpall祝辞/usr/local/pgsql/backup/pg_all.dmp

5,删除数据库

dropdb pg1

dropdb pg2

6,恢复数据库

psql - f/usr/local/pgsql/backup/pg_all.dmp postgres

可以指定任何数据库名,如果恢复到一个空的集群中,通常使用postgres数据库

7日查看数据库pg1是否恢复

psql pg1

pg=# select * from tb1;

(1行)

8日查看数据库pg2是否恢复

psql pg2

pg=# select * from tb2;

(1行)

至此,数据已成功恢复!

(三)备份压缩与分割

压缩与分割的原理都是利用Linux的管线(管)命令,不再进行试验。

1)压缩

l备份:

pg_dump dbname | gzip祝辞文件名。广州

l恢复

gunzip - c文件名。广州| psql dbname

2)分割

l备份:

pg_dump dbname |分割-b1m——文件名

l恢复

猫文件名* | psql dbname

三、文件系统级别备份(冷备份)

文件系统级别的备份是冷备份,需要停止数据库。

1,停止数据库

pg_ctl - d/usr/local/pgsql/data停止

2,备份数据库

沥青-jcv - f/usr/local/pgsql/backup/filesystem.tar。bz2/usr/local/pgsql/data/获取

3,删除/usr/地方/pgsql/数据/目录rm - r/usr/local/pgsql/data/

4,解压备份文件到原目录

沥青-jxv - f/usr/local/pgsql/backup/filesystem.tar。bz2 - c获?

5,启动数据库

pg_ctl - d/usr/local/pgsql/data开始

6,查看数据库pg1是否恢复

psql pg1

pg=# select * from tb1;

(1行)

7日查看数据库pg2是否恢复

psql pg2

pg=# select * from tb2;

(1行)

至此,数据已成功恢复!

四,在线热备份(归档)

(一)备份

1,配置归档模式

配置归档需要编辑postgresql。参看文件,默认为与/usr/地方/pgsql/数据/目录下

vim/usr/local/pgsql/data/postgesql.参看

archive_mode=>关于恢复postgresql数据库的方法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看的到。

恢复postgresql数据库的方法