返回顶部
首页 > 资讯 > 数据库 >postgresql学习笔记(五)备份与恢复
  • 120
分享到

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

2024-04-02 19:04:59 120人浏览 独家记忆
摘要

postgresql学习笔记(五)备份与恢复1、备份工具:pg_dump和pg_dumpallpg_dump可备份一个指定的databasepg_dumpall可一次性备份所有database的数据及系统全

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,备份结果以自定压缩格式输出 :

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

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

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

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

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中的所有数据,备份结果以自定义压缩格式输出:

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中的数据以外的所有数据,备份结果以自定义压缩格式输出:

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数据库中。

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

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

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

(8)目录格式并行备份

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)仅备份角色和表空间定义

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

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

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备份文件并忽略过程中可能发生的所有错误

psql -U postgres -f myglobals.sql

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

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

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

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


10、使用pg_restore进行恢复

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

create database mydb;

 执行恢复:

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

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

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

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

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


您可能感兴趣的文档:

--结束END--

本文标题: postgresql学习笔记(五)备份与恢复

本文链接: https://lsjlt.com/news/38023.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • postgresql学习笔记(五)备份与恢复
    postgresql学习笔记(五)备份与恢复1、备份工具:pg_dump和pg_dumpallpg_dump可备份一个指定的databasepg_dumpall可一次性备份所有database的数据及系统全...
    99+
    2024-04-02
  • MySQL学习笔记(27):备份与恢复
    本文更新于2020-05-03,使用MySQL 5.7,操作系统为Deepin 15.4。 目录逻辑备份和恢复物理备份和恢复冷备份和恢复热备份和恢复表数据导入导出 MySQL的备份分为逻辑备份和物理备份,物理备份分为冷备份和热备份...
    99+
    2021-04-04
    MySQL学习笔记(27):备份与恢复
  • mysql学习笔记之备份与恢复
    5 .备份恢复 相关关...
    99+
    2024-04-02
  • MongoDB备份恢复笔记
    1、全量逻辑备份/恢复 Mongodump/Mongorestore对于数据量比较小的场景,使用官方的mongodump/mongorestore工具进行全量的备份和恢复就足够了。mongodump可以连上...
    99+
    2024-04-02
  • Oracle备份与恢复(五)
    备份:   定义:      把数据库复制到转储设备的过程。      转储设备:  ...
    99+
    2024-04-02
  • MySQL 学习笔记(五)
    mysqldump 与 --set-gtid-purged 设置 (1)  mysqldump The mysqldump client utility performs logical backups, producing a set ...
    99+
    2022-01-27
    MySQL 学习笔记(五)
  • Python学习笔记五(Python
    Python urllib模块提供了一个从指定的URL地址获取网页数据,然后对其进行分析处理,获取想要的数据。1.查看urllib模块提供的urlopen函数。help(urllib.urlopen) urlopen(url, data...
    99+
    2023-01-31
    学习笔记 Python
  • PostgreSQL备份与恢复策略是什么
    PostgreSQL备份与恢复策略是指在使用PostgreSQL数据库时,为了保障数据安全和可靠性,需要定期备份数据库,并能够在需要...
    99+
    2024-04-09
    PostgreSQL
  • postgresql使用pg_rman备份恢复
    os:centos 7.5 postgresql: 10.01.软件下载:https://github.com/ossc-db/pg_rman/releases/pg_rman-1.3.7-1.pg10.r...
    99+
    2024-04-02
  • Python第五周 学习笔记(2)
    一、实现一个cache装饰器,实现可过期被清除的功能 简化设计,函数的形参定义不包含可变位置参数、可变关键词参数和keyword-only参数 可以不考虑缓存满了之后的换出问题 1)原始 def cache(fn): imp...
    99+
    2023-01-31
    学习笔记 Python
  • Python学习笔记整理(五)Pytho
    列表和字段,这两种类型几乎是Python所有脚本的主要工作组件。他们都可以在原处进行修改,可以按需求增加或缩短,而且包含任何种类的对象或者被嵌套。 一、列表 列表的主要属性: *任意对象的有序集合 ...
    99+
    2023-01-31
    学习笔记 Python Pytho
  • 学习笔记-小甲鱼Python3学习第五讲
    数据类型:整型、浮点型、布尔型整型:1、234、54浮点型:12.234、2.3e5 = 230000.0、1.5e-3 = 0.0015布尔型:True、False。True + True 返回 2,True + False 返回1,Tr...
    99+
    2023-01-31
    甲鱼 学习笔记
  • 学习笔记-小甲鱼Python3学习第十五
    字符串格式化符号含义符号说明%c格式化字符及其 ASCII 码%s格式化字符串%d格式化整数%o格式化无符号八进制数%x格式化无符号十六进制数%X格式化无符号十六进制数(大写)%f格式化浮点数字,可指定小数点后的精度%e用科学计数法格式化浮...
    99+
    2023-01-31
    甲鱼 学习笔记
  • mysql备份与恢复
    1、备份命令(用户名:root;密码:123;端口:3306) 格式:mysqldump -h主机名 -p端口 -u用户名 -p密码 --database 数据库名 > 文件名.sql 例如: mysqldump -h 192.1...
    99+
    2015-05-28
    mysql备份与恢复
  • MongoDB备份与恢复
           mongodb和mysql很相似,那么它是否也和mysql一样可以备份数据库和恢复数据库呢?那是当然的,下面将简单介绍mo...
    99+
    2024-04-02
  • mongodb 备份与恢复
    一、整库备份:mongodump -h dbhost -d dbname -o dbdirectory-h:MongDB所在服务器地址,例如:127.0.0.1,当然也可以指定端口号:127.0.0.1:2...
    99+
    2024-04-02
  • 备份与恢复—RMAN1
    [TOC]...
    99+
    2024-04-02
  • DB2备份与恢复
    DB2 备份与恢复 整理下16年写的DB2相关文档,换工作以后一直没用过DB2,忘的差不多了。 一 db2 backup/restore 备份和恢复 1.1 备份 db2...
    99+
    2024-04-02
  • Redis学习笔记(五) 压缩列表
    压缩列表是列表键与哈希键的底层实现之一。当一个列表键只包含少量的列表项,并且每个列表项要么就是小整数值,要么就是长度较短的字符串,那么Redis就会使用压缩列表来做列表键的底层实现。 压缩列表是为了节约内存而开发的,是由一系列特殊...
    99+
    2016-06-12
    Redis学习笔记(五) 压缩列表
  • Android学习笔记(五)——RadioGroup&RadioButton
    实现RadioButton由两部分组成,也就是RadioButton和RadioGroup配合使用. RadioGroup是单选组合框,可以容纳多个RadioButton的容器. 在没有RadioGroup的情况下,RadioBut...
    99+
    2022-06-06
    android学习 radiobutton radiogroup Android
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作