温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

恢复postgresql数据库的方法

发布时间:2020-07-24 15:10:29 来源:亿速云 阅读:346 作者:清晨 栏目:编程语言

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

Postgresql的备份分为三种:

SQL转储

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

在线热备份(归档)

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

二、 SQL转储

(一)pg_dump

1,创建数据库

createdb pg

2,连入数据库pg

psql pg

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

pg=# create table pg_test(a int);

pg=# insert into pg_test(a) values(1);

pg=# insert into pg_test(a) values(2);

4,查看数据

pg=# select * from tb;

a

(2 rows)

5,备份

pg_dump pg > /usr/local/pgsql/backup/pg.dmp

6,删除数据库pg

dropdb pg

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

createdb pg

8,恢复数据

psql pb < /usr/local/pgsql/backup/pg.dmp

9,查看数据是否回复

pg=# select * from tb;

(2 rows)

至此,数据已成功恢复!

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

如:pg_dump databasename –t tablename1 –t tablename2 >filename

(二)pg_dumpall

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

1,创建数据库

createdb pg1

createdb pg2

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

psql pg1

pg=# create table tb1(a int)

pg=# insert into tb1(a) values(1);

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

psql pg2

pg=# create table tb2(a int)

pg=# insert into tb2(a) values(2);

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 rows)

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

psql pg2

pg=# select * from tb2;

(1 rows)

至此,数据已成功恢复!

(三)备份压缩与分割

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

1)压缩

l 备份:

pg_dump dbname | gzip > filename.gz

l 恢复

gunzip -c filename.gz | psql dbname

2)分割

l 备份:

pg_dump dbname | split -b1m- filename

l 恢复

cat filename* | psql dbname

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

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

1,停止数据库

pg_ctl –D /usr/local/pgsql/data stop

2,备份数据库

tar –jcv –f /usr/local/pgsql/backup/filesystem.tar.bz2 /usr/local/pgsql/data/

3,删除/usr/local/pgsql/data/目录

rm –r /usr/local/pgsql/data/

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

tar –jxv –f /usr/local/pgsql/backup/filesystem.tar.bz2 –C /

5,启动数据库

pg_ctl –D /usr/local/pgsql/data start

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

psql pg1

pg=# select * from tb1;

(1 rows)

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

psql pg2

pg=# select * from tb2;

(1 rows)

至此,数据已成功恢复!

四、在线热备份(归档)

(一)备份

1,配置归档模式

配置归档需要编辑postgresql.conf文件,默认为与/usr/local/pgsql/data/目录下

vim /usr/local/pgsql/data/postgesql.conf

archive_mode = on

archive_command = ‘cp %p /usr/local/pgsql/backup/archived_log/%f’

注:%p要被归档的日志文件的路径,%f是要被归档的日志文件的文件名

2,启动数据库

pg_ctl –D /usr/local/pgsql/data start

3,创建数据库arch

createdb arch

4,创建表并插入记录

psql arch

arch=# create table tb(a int);

arch=# insert into tb(a) values(1);

5,创建备份

arch=# select pg_start_backup(‘baseline’);

6,备份整个data目录

tar –jcv –f /usr/local/pgsql/backup/baseline.tar.bz2 /usr/local/pgsql/data/

7,停止备份

psql arch

arch=# select pg_stop_backup();

8,插入新记录,然后切换日志,重复3次

arch=# insert into tb(a) values(2);

arch=# select pg_switch_xlog();

arch=# insert into tb(a) values(3);

arch=# select pg_switch_xlog();

arch=# insert into tb(a) values(4);

arch=# select pg_switch_xlog();

9,把/data/pg_xlog/下的WAL日志文件复制到预设的归档目录下,保证产生的WAL日志都已归档。

(二)恢复

1,停止数据库

pg_ctl –D /usr/local/pgsql/data/ stop

2,删除/data/

rm –r /usr/local/pgsql/data/

3,恢复备份

tar –jxv –f /usr/local/pgsql/backup/baseline.tar.bz2 –C /

4,清空/data/pg_xlog/目录下所有文件

rm –r /usr/local/pgsql/data/pg_xlog/

5,创建/pg_xlog/及其下面的archive_status目录

mkdir /usr/local/pgsql/data/pg_xlog/

mkdir /usr/local/pgsql/data/pg_xlog/archive_status

6,在/data/目录下创建recovery.conf

vim /usr/local/pgsql/data/recovery.conf

restore_command = ‘cp /usr/local/pgsql/backup/archived_log/%f “%p”’

7,启动数据库

pg_ctl –D /usr/local/pgsql/data/ start

一切正常的话数据库就会自动应用WAL日志进行恢复

8,查看数据库arch是否恢复

psql arch

arch=# select * from tb;

(4 rows)

至此,数据已经成功恢复!

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

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI