PostgreSQL备份与恢复示例_pgsql备份表数据结构和数据

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

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;

a


1

(1 rows)

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

psql pg2

pg=# select * from tb2;

a


2

(1 rows)

至此,数据已成功恢复!

(三)备份压缩与分割

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

1
)压缩


备份:

pg_dump dbname | gzip > filename.gz


恢复

gunzip -c filename.gz | psql dbname

2
)分割


备份:

pg_dump dbname | split -b1m- filename


恢复

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;

a


1

(1 rows)

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

psql pg2

pg=# select * from tb2;

a


2

(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;

a


1

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化的资料的朋友,可以戳这里获取

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

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

psql arch

arch=# select * from tb;

a


1

[外链图片转存中…(img-rgD8s1h3-1715815581429)]
[外链图片转存中…(img-WfDMjYoE-1715815581429)]
[外链图片转存中…(img-AHQUa1LF-1715815581430)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化的资料的朋友,可以戳这里获取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值