PostgreSQL教程(7)数据备份与还原
一、 PostgreSQL逻辑备份与还原工具——pg_dump、pg_restore、pg_dumpall
1、pg_dump常用选项
-U:指定用户名
-W:指定密码
-F :指定备份格式,默认备份文件为sql格式
-lock-wait-timeout=10s:备份时锁超时时间。避免备份期间有事务一直未执行完成导致备份卡住
--exclude-table=TABLE_NAME:指定不需要备份的表
--exclude-schema=SCHEMA_NAME:指定不需要备份的SCHEMA
2、pg_dump备份与还原
#方法1:备份linuxe库的数据为SQL格式然后进行还原 pg_dump -h 192.168.0.103 -U tanglu linuxe > linuxe.sql psql -h 192.168.0.103 -U tanglu -d linuxe -f linxue.sql #恢复数据前需要先创建好数据库 #使用restore还原的方式 pg_dump -h 192.168.0.103 -U tanglu -Fc linuxe > linuxe.dump #-F指定格式为dump专有格式 pg_restore -h 192.168.0.103 -U tanglu -d linuxe linxue.dump #还原数据到linuxe库中
3、使用pg_dumpall备份,加选项可以只备份表结构等
pg_dumpall -h 192.168.0.103 > pg_all.sql #所有库 psql -h 192.168.0.103 -U tanglu -d linuxe -f pg_all.sql
二、 PostgreSQL物理备份工具——pg_rman、pg_basebackup(使用物理备份方式需要先配置好归档文件,非归档模式下数据库将覆盖掉日志文件)
1、pg_rman常用选项
-B:指定备份数据存放路径
-D:指定需要备份的数据路径
-b:指定备份方式,如full、incremental
2、pg_rman的使用(该工具需要先安装)
pg_rman -B /data/backup/pgsql/ -D /data/postgresql/data/ init #初始化备份目录 pg_rman -h 192.168.0.104 -Upostgres -B /data/backup/pgsql/ -D /data/postgresql/data/ -d linuxe -b full backup #全备 pg_rman -h 192.168.0.103 -D /data/postgresql/ -b incremental backup #增量备份 pg_rman -B /data/backup/pgsql/ validate #备份后需要进行数据校验 pg_rman show #查看历史备份 pg_rman delete "2020-08-28 22:16:22" #删除某个历史备份
#恢复数据 rm -rf /data/postgresql/data/* pg_rman restore #一条命令完成恢复
3、pg_basebackup的使用(在进行主从部署的时候已经接触过该工具,pg_basebackup作为备份工具的时候可以把指定实例中所有数据(全量备份+WAL日志)都拷贝出来,在还原的时候会先恢复全备数据,然后再重放WAL日志)
版权声明:本文章版权归数据库运维网(www.ywdba.cn)所有。如需引用本站内容,请注明来源及作者。
评论