postgresql学习笔记(五)备份与恢复

本文涉及的产品
云原生数据库 PolarDB MySQL 版,通用型 2核4GB 50GB
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
简介:

postgresql学习笔记(五)备份与恢复

1、备份工具:pg_dump和pg_dumpall

pg_dump可备份一个指定的database

pg_dumpall可一次性备份所有database的数据及系统全局数据

2、pg_dump和pg_dumpall工具不支持在命令行选项中设定登录密码,因此为了便于执行自动任务,你需要在postgres操作系统帐号的home文件夹下创建一个密码文件.pgpass来存储密码;或者也可以用PGPASSWORD环境变量来设定密码。

3、如果你希望每天都进行备份,那么使用pg_dump比pg_dumpall更合适,因为前者支持精确指定要备份的表,schema和database,而后者不支持。

4、pg_dump可以将数据备份为SQL文本文件格式,也支持备份为用户定义压缩格式或者是TAR包格式,在数据恢复时,对压缩格式和TAR包格式的备份文件可以实现并行恢复,该特性是从8.4版开始支持的。

5、pg_dumpall工具可以将当前postgresql服务实例中所有database的数据都导出为SQL文本(pg_dumpall不支持导出SQL文本以外的其他格式),也可以同时导出表间定义和角色等全局对象。

6、pg_dump用法:

(1)备份某个database,备份结果以自定压缩格式输出 :

1
pg_dump -h 127.0.0.1 -p 5432 -U postgres -F c -b -v -f test.backup test

(2)备份某个database,备份结果以SQL文本方式输出,输出结果中需包括CREATE DATABASE语句;

1
pg_dump -h 127.0.0.1 -p 5432 -U postgres -C -F p -b -v -f test.sql test

(3)备份某个database中所有名称以“pay”开头的表,备份结果以自定义压缩格式输出:

1
pg_dump -h 127.0.0.1 -p 5432 -U postgres -F c -b -v -t *.pay* -f pay.backup test

(4)备份某个database中hr和payroll这两个schema中的所有数据,备份结果以自定义压缩格式输出:

1
pg_dump -h 127.0.0.1 -p 5432 -U postgres -F c -b -v -n hr -n payroll -f hr.backup mydb

(5)备份某个database中除了public schema中的数据以外的所有数据,备份结果以自定义压缩格式输出:

1
pg_dump -h 127.0.0.1 -p 5432  -U postgres -F c -b -v -N  public  -f all_sch_except_pub.backup mydb

(6)将数据备份为SQL文本文件,且生成的INSERT语句是带有字段名列表的标准格式,该文件可用于将数据导入到低于当前版本的PostgreSQL或者其他支持SQL的非PostgreSQL数据库中。

1
pg_dump -h 127.0.0.1 -p 5432  -U postgres -F p  --column-inserts -f select_tables.backup mydb

(7)目录格式备份,解决了以其他备份格式时可能存在的单个文件大小超出操作系统限制的问题

1
pg_dump -h 127.0.0.1 -p 5432  -U postgres -F d -f /somepath/a_directory mydb

(8)目录格式并行备份

1
pg_dump -h 127.0.0.1 -p 5432  -U postgres -j 3 -Fd -f /somepath/a_directory mydb

7、pg_dumpall 建议每天都对角色和表空间定义等全局对象进行备份,但不建议每天都使用pg_dumpall来备份全库数据,因为pg_dumpall仅支持导出为SQL文本格式,而使用这种庞大的SQL文本备份来进行全库级别

的数据恢复是极其耗时的,所以一般只建议用pg_dumpall来备份全局对象而非全库数据,如果你一定要用pg_dumpall来备份全库数据的话,一般一个月执行一次就够了。

(1)仅备份角色和表空间定义

1
pg_dumpall -h localhost -U postgres  --port=5432 -f myglobals.sql --globals-only

 (2)仅需备份角色定义而无需备份表空间,那么可以加上--roles-only选项

1
pg_dumpall -h localhost -U postgres  --port=5432 -f myglobals.sql --roles-only

8、数据恢复方法

(1)使用psql来恢复pg_dump或者pg_dumpall工具生成的SQL文本格式的数据备份;

(2)使用pg_restore工具来恢复由pg_dump工具生成的自定义压缩格式,TAR包格式或者目录格式备份

9、使用psql恢复SQL文本格式的数据备份

 (1)恢复一个SQL备份文件并忽略过程中可能发生的所有错误

1
psql -U postgres -f myglobals.sql

(2)恢复一个SQL备份文件,如遇任何错误则立好停止恢复

1
psql -U postgres  --set ON_ERROR_STOP=on -f myglobals.sql

(3)将SQL文本中的数据恢复到某个指定的database:

1
psql -U postgres -d mydb -f select_objects.sql


10、使用pg_restore进行恢复

(1)在使用pg_restore执行恢复动作之前,请创建目标数据库

1
create  database  mydb;

 执行恢复:

1
pg_restore  --dbname=mydb --jobs=4 --verbose mydb.backup

 (2)如果备份和恢复时使用的database同名,则可以通过加--create选项省去单独建库的过程

1
pg_restore  --dbname=postgres --create --jobs=4 --verbose mydb.backup

 (3)恢复表结构而不恢复表数据

1
2
create  database  mydb2;
pg_resotre  --dbname=mydb2 --section=pre-data --jobs=4 mydb.backup


本文转自 corasql 51CTO博客,原文链接:http://blog.51cto.com/corasql/1920949,如需转载请自行联系原作者
相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
5月前
|
存储 关系型数据库 数据库
PostgreSQL的备份策略
【8月更文挑战第4天】PostgreSQL的备份策略
164 4
|
5月前
|
存储 Ubuntu 关系型数据库
如何在 Ubuntu VPS 上备份 PostgreSQL 数据库
如何在 Ubuntu VPS 上备份 PostgreSQL 数据库
42 1
|
5月前
|
关系型数据库 数据库 PostgreSQL
Linux 环境手动备份postgresql数据库
【8月更文挑战第12天】在Docker环境中使用命令行工具对PostgreSQL数据库进行备份和恢复。首先,通过dockerexec进入容器,使用pg_dump进行数据库模式的备份,然后使用dockercp将备份文件导出。接着,若需导入数据到另一数据库,先将备份文件复制到目标容器,再利用psql命令进行数据恢复。整个过程需确保目标数据库无同名模式,以防止导入失败
70 3
|
5月前
|
存储 监控 关系型数据库
PostgreSQL的备份策略是什么?
【8月更文挑战第4天】PostgreSQL的备份策略是什么?
80 7
|
5月前
|
SQL 关系型数据库 数据库
[postgresql]逻辑备份与还原
[postgresql]逻辑备份与还原
|
6月前
|
存储 关系型数据库 分布式数据库
PolarDB产品使用问题之如何查看PolarDB for PostgreSQL的备份信息
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
8月前
|
关系型数据库 数据库 PostgreSQL
postgresql|【基于pg_basebackup命令的归档备份和恢复---热备冷恢复方式】
postgresql|【基于pg_basebackup命令的归档备份和恢复---热备冷恢复方式】
337 0
|
8月前
|
关系型数据库 数据库 PostgreSQL
PostgreSQL从小白到高手教程 - 第41讲:postgres表空间备份与恢复
PostgreSQL从小白到高手教程 - 第41讲:postgres表空间备份与恢复
220 1
|
8月前
|
Kubernetes 关系型数据库 分布式数据库
PolarDB for PostgreSQL备份问题之备份损坏如何解决
PolarDB for PostgreSQL是基于PostgreSQL开发的一款云原生关系型数据库服务,它提供了高性能、高可用性和弹性扩展的特性;本合集将围绕PolarDB(pg)的部署、管理和优化提供指导,以及常见问题的排查和解决办法。
|
8月前
|
SQL 关系型数据库 MySQL
postgresql |数据库 |数据库的常用备份和恢复方法总结
postgresql |数据库 |数据库的常用备份和恢复方法总结
258 0