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,如需转载请自行联系原作者

postgresql学习笔记(五)备份与恢复相关推荐

  1. PostgreSQL学习笔记(更新ing)+c# 使用ef连接数据库postgreSQL

    目录 PostgreSQL学习笔记 一.PostgreSQL创建.删除数据库(表).架构 1.创建数据库 CREATE DATABASE 2.查看数据库 3.删除数据库 4.创建表 5.删除表 6.架 ...

  2. PostgreSQL学习手册(五) 函数和操作符

    PostgreSQL学习手册(五) 函数和操作符 一.逻辑操作符:     常用的逻辑操作符有:AND.OR和NOT.其语义与其它编程语言中的逻辑操作符完全相同. 二.比较操作符:     下面是Po ...

  3. python函数是一段具有特定功能的语句组_Python学习笔记(五)函数和代码复用

    本文将为您描述Python学习笔记(五)函数和代码复用,具体完成步骤: 函数能提高应用的模块性,和代码的重复利用率.在很多高级语言中,都可以使用函数实现多种功能.在之前的学习中,相信你已经知道Pyth ...

  4. Ethernet/IP 学习笔记五

    Ethernet/IP 学习笔记五 Accessing data within a device using a non-time critical message (an explicit mess ...

  5. StackExchange.Redis学习笔记(五) 发布和订阅

    StackExchange.Redis学习笔记(五) 发布和订阅 原文:StackExchange.Redis学习笔记(五) 发布和订阅 Redis命令中的Pub/Sub Redis在 2.0之后的版 ...

  6. 吴恩达《机器学习》学习笔记五——逻辑回归

    吴恩达<机器学习>学习笔记五--逻辑回归 一. 分类(classification) 1.定义 2.阈值 二. 逻辑(logistic)回归假设函数 1.假设的表达式 2.假设表达式的意义 ...

  7. 好程序员教程分析Vue学习笔记五

    好程序员教程分析Vue学习笔记五,上次我们学习了Vue的组件,这次我们来学习一下路由的使用.在Vue中,所谓的路由其实跟其他的框架中的路由的概念差不多,即指跳转的路径. 注意:在Vue中,要使用路由, ...

  8. 【AngularJs学习笔记五】AngularJS从构建项目开始

    为什么80%的码农都做不了架构师?>>>    #0 系列目录# AngularJs学习笔记 [AngularJs学习笔记一]Bower解决js的依赖管理 [AngularJs学习笔 ...

  9. ROS学习笔记五:理解ROS topics

    ROS学习笔记五:理解ROS topics 本节主要介绍ROS topics并且使用rostopic和rqt_plot命令行工具. 例子展示 roscore 首先运行roscore系列服务,这是使用R ...

  10. Spring Boot 框架学习笔记(五)( SpringSecurity安全框架 )

    Spring Boot 框架学习笔记(五) SpringSecurity安全框架 概述 作用 开发示例: 1. 新建项目 2. 引入依赖 3. 编写`SecurityConfig`类,实现认证,授权, ...

最新文章

  1. net core mysql 连接池_EF Core 小坑:DbContextPool 会引起数据库连接池连接耗尽
  2. java aab全排列_编译原理习题课答案.ppt
  3. 【Java数据结构】3.1 顺序栈
  4. python安装各种插件
  5. 中南大学计算机网.doc,中南大学计算机网络习题2014-2.doc
  6. 20181027_任务
  7. ant vue 树形菜单横向显示_丝滑般 Vue 拖拽排序树形表格组件Vue-DragTreeTable
  8. 五、bootstrap-fileinput
  9. 利用java反射根据方法名称字符串调用方法
  10. C# 不借助第三个变量实现两整数交换
  11. 你想学的都在这里!传智播客java就业班教程
  12. 【微信支付】springboot 微信app支付包括回调通知
  13. 网络游戏外挂制作(3)
  14. 【杂记】数据存储架构
  15. SyncToy多电脑工作离线同步/备份方案
  16. 有了这个“神级”功能,会Excel就能轻松玩转BI数据可视化分析啦
  17. zip直链生成网站_防止赖床的闹钟软件、免费好用的看图软件、色卡生成器 今天有什么?...
  18. Python 语音播报
  19. outlook不断弹出“对以下服务器输入您的用户名和密码”
  20. 动软代码生成器 第一次使用出现附加数据库错误是否添加写入权限

热门文章

  1. 在lamp上简单部署应用程序
  2. TCP连接、Http连接与Socket连接
  3. Activator.CreateInstance 方法 (Type) 的用法
  4. 一个有趣的.net程序死锁问题
  5. C# .Net中的类型转换(5)
  6. Psychology
  7. ES6中的const命令【转】
  8. 没想到,我能这么细心地看算法
  9. 最简单爬虫rvest_告别复制粘贴
  10. 内推|网易高级数据分析师(地点:杭州)