PostgreSQL逻辑备份与恢复

news/2024/7/9 22:42:27 标签: postgresql, 数据库

PostgreSQL逻辑备份与恢复

  • 逻辑备份:pg_dump
  • 逻辑备份:pg_dumpall
  • 逻辑恢复:psql和pg_restore

PostgreSQL逻辑备份恢复的官方工具是pg_dump、pg_dumpall、pg_restore。

  • pg_dump:支持对数据库或表进行备份,导出文件可以是SQL文件或归档文件(默认是纯SQL文本)。
  • pg_dumpall:支持对整个数据库进行备份,只支持导出为SQL文件。
  • pg_restore:用于将pg_dump导出的归档文件恢复到数据库

逻辑备份:pg_dump

备份数据库

备份单个数据库

#格式:pg_dump -h${DB_IP} -p${DB_PORT} -U ${BACKUP_USER} ${DBNAME} > dump.sql
pg_dump sekiro > sekiro_db.sql

#导出为可用于pg_restore恢复的dump文件(选项-Fc)
pg_dump -Fc sekiro > sekiro_db.dump

备份表

#备份指定表:-t
#格式:pg_dump -h${DB_IP} -p${DB_PORT} -U ${BACKUP_USER} -t ${SCHEMA.TABLENAME} ${DBNAME} > dump.sql

pg_dump -t public.map sekiro > sekiro_map.sql
pg_dump -t map sekiro > sekiro_map.sql          # public schema可省略

#备份指定表以外的表:-T
#格式:pg_dump -h${DB_IP} -p${DB_PORT} -U ${BACKUP_USER} -T ${SCHEMA.TABLENAME} ${DBNAME} > dump.sql

pg_dump -T map sekiro > sekiro_exclude_map.sql

#备份通配符匹配的表
pg_dump -t 'public.st*' sekiro > sekiro_table.sql    # 备份public schema中名称以st开头的表
pg_dump -T 'public.*day' sekiro > sekiro_table.sql   # 备份public schema中名称以day结尾的表以外的其他所有表

备份Schema

#备份指定Schema:-n,不能与-t结合使用
#格式:pg_dump -h${DB_IP} -p${DB_PORT} -U ${BACKUP_USER} -n ${SCHEMA} ${DBNAME} > dump.sql

pg_dump -n public sekiro > sekiro_public.sql

#备份指定Schema以外的Schema:-N
#格式:pg_dump -h${DB_IP} -p${DB_PORT} -U ${BACKUP_USER} -N ${SCHEMA} ${DBNAME} > dump.sql

pg_dump -N public sekiro > sekiro_exclude_public.sql

逻辑备份:pg_dumpall

pg_dumpall用于将一个数据库中的所有数据都备份到一个SQL文件中,还可以备份所有数据库的全局共用对象、数据库用户和角色权限。

#备份所有数据库
pg_dumpall > backup.sql

#备份全局角色和表空间
pg_dumpall --globals-only > globals.sql

#备份角色定义
pg_dumpall --roles-only > roles.sql

逻辑恢复:psql和pg_restore

PostgreSQL进行逻辑恢复可以用到psql和pg_restore工具。PSQL可以用来恢复pg_dump和pg_dumpall导出的SQL文本。PG_RESTORE可以用来恢复pg_dump导出的dump文件。

恢复数据库

示例:PSQL恢复数据库

psql -f backup.sql
psql < backup.sql

示例:PG_RESTORE恢复数据库

#备份数据库
pg_dump -Fc sekiro > sekiro_db.dump

#删除数据库
postgres=# drop database sekiro;
DROP DATABASE
postgres=# \l
                                  List of databases
   Name    |  Owner   | Encoding |   Collate   |    Ctype    |   Access privileges   
-----------+----------+----------+-------------+-------------+-----------------------
 postgres  | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 template0 | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +
           |          |          |             |             | postgres=CTc/postgres
 template1 | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +
           |          |          |             |             | postgres=CTc/postgres
 testdb    | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
(4 rows)


#恢复数据库(需要先创建库)
psql -c "create database sekiro with owner=sekiro tablespace=sekiro"
pg_restore -d sekiro sekiro_db.dump

#检查恢复后的数据库
postgres=# \l
                                  List of databases
   Name    |  Owner   | Encoding |   Collate   |    Ctype    |   Access privileges   
-----------+----------+----------+-------------+-------------+-----------------------
 postgres  | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 sekiro    | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 template0 | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +
           |          |          |             |             | postgres=CTc/postgres
 template1 | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +
           |          |          |             |             | postgres=CTc/postgres
 testdb    | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
(5 rows)

postgres=# \c sekiro sekiro
You are now connected to database "sekiro" as user "sekiro".
sekiro=> select * from map;
 map_id |    map_name     
--------+-----------------
      1 | Senhen Temple
      2 | Fountain Palace
(2 rows)

恢复表

恢复表时,如果用于恢复的备份文件不是单表备份,可以通过选项-t指定要恢复的表,选项-d指定要恢复到的数据库

下面两个示例分别展示了使用psql和pg_restore工具恢复表的方法。

示例:PSQL恢复表

#导出map表备份
pg_dump -t map sekiro > sekiro_map.sql 

#删除map表
postgres=# \c sekiro sekiro
You are now connected to database "sekiro" as user "sekiro".
sekiro=> \dt
        List of relations
 Schema | Name  | Type  | Owner  
--------+-------+-------+--------
 public | map   | table | sekiro
 public | staff | table | sekiro
(2 rows)

sekiro=> drop table map;
DROP TABLE
sekiro=> \dt
        List of relations
 Schema | Name  | Type  | Owner  
--------+-------+-------+--------
 public | staff | table | sekiro
(1 row)

#恢复表(-d指定数据库
psql -d sekiro < sekiro_map.sql 

#检查恢复后的数据
postgres=# \c sekiro sekiro
You are now connected to database "sekiro" as user "sekiro".
sekiro=> \dt
        List of relations
 Schema | Name  | Type  | Owner  
--------+-------+-------+--------
 public | map   | table | sekiro
 public | staff | table | sekiro
(2 rows)

sekiro=> select * from map;
 map_id |    map_name     
--------+-----------------
      1 | Senhen Temple
      2 | Fountain Palace
(2 rows)

示例:PG_RESTORE恢复表

#导出map表备份
pg_dump -t map -Fc sekiro > sekiro_map.dump 

#删除map表
postgres=# \c sekiro sekiro
You are now connected to database "sekiro" as user "sekiro".

sekiro=> drop table map;
DROP TABLE
sekiro=> \dt
        List of relations
 Schema | Name  | Type  | Owner  
--------+-------+-------+--------
 public | staff | table | sekiro
(1 row)

#恢复表(-d指定数据库
pg_restore -d sekiro sekiro_map.dump

#检查恢复后的数据
postgres=# \c sekiro sekiro
You are now connected to database "sekiro" as user "sekiro".
sekiro=> \dt
        List of relations
 Schema | Name  | Type  | Owner  
--------+-------+-------+--------
 public | map   | table | sekiro
 public | staff | table | sekiro
(2 rows)

sekiro=> select * from map;
 map_id |    map_name     
--------+-----------------
      1 | Senhen Temple
      2 | Fountain Palace
(2 rows)

恢复Schema

恢复Schema与恢复表类似。使用pg_restore恢复schema时,使用-n选项来恢复指定的Schema。


http://www.niftyadmin.cn/n/5115848.html

相关文章

【单片机学习笔记】Windows+Vscode+STM32F4+freeRTOS+FatFs gcc环境搭建

为摒弃在接受keil邮件&#xff0c;研究了下gun编译&#xff0c;以STM32F407为例&#xff0c;简单记录 1. 软件包准备 Git 选择对应版本直接安装即可https://git-scm.com/download/winmakegcc ​ 1&#xff09;将上述软件包放置于C盘根目录 2&#xff09;添加环境变量 3&am…

AS/NZS 1859.3:2017 木基装饰板检测

木基装饰板是指以木质材料为基材&#xff0c;比如刨花板&#xff0c;胶合板等木质人造板&#xff0c;表面贴有PVC膜&#xff0c;三聚氰胺纸&#xff0c;木饰面等装饰层压制而成的木质复合材料&#xff0c;主要用于墙面装饰&#xff0c;家具等领域。 AS/NZS 1859.3&#xff1a;…

第一届猿人学爬虫比赛1-20题题解

文章目录 这次把之前写的猿人学题解整合一下&#xff0c;方便大家索引查看&#xff0c;先提前说一下这些题解大部分都在我的付费专栏 JS逆向百例 里&#xff0c;专栏价格49.9 &#xff0c;平台扣除20&#xff0c;我实际能收到29.9 &#xff0c;一杯咖啡钱&#xff0c;穷不了你富…

牛客周赛 Round 16

A、 题目描述 给定一个大小为n的数组a&#xff0c;请你判断一个数组是否满足以下条件&#xff1a; 1. 数组严格升序&#xff0c;即a1<a2<...<an。 2. 对于1≤i≤n−1&#xff0c;我们定义bi​a(i1​)−ai​&#xff0c;则数组b严格降序&#xff0c;即b1​>b2​>…

k8s-----9、pod 影响调度的因素

资源限制和节点选择器 1、pod资源限制2、节点选择器&#xff08;pod属性&#xff09;3、 节点亲和性(nodeAffinity)&#xff08;pod属性&#xff09;3.1 硬和软亲和性3.2 反亲和性 4、污点&#xff08;taint&#xff09;和污点容忍&#xff08;节点属性&#xff09;4.1 定义4.2…

华为OD 完全二叉树非叶子部分后序遍历(200分)【java】A卷+B卷

华为OD统一考试A卷+B卷 新题库说明 你收到的链接上面会标注A卷还是B卷。目前大部分收到的都是B卷。 B卷对应往年部分考题以及新出的题目,A卷对应的是新出的题目。 我将持续更新最新题目 获取更多免费题目可前往夸克网盘下载,请点击以下链接进入: 我用夸克网盘分享了「华为OD…

Hikari 介绍

一、什么是数据库连接池 数据库连接池是一种管理和复用数据库连接的技术。在应用程序中&#xff0c;连接数据库是一项耗费资源和时间的操作。传统上&#xff0c;每次需要与数据库交互时&#xff0c;应用程序都会创建一个新的数据库连接&#xff0c;并在使用完成后关闭连接。然…

【网络协议】聊聊网络路由相关算法

如何配置路由 路由器是一台网络设备&#xff0c;多张网卡&#xff0c;当一个入口的网络包到达路由器时&#xff0c;会根据本地的信息库决定如何正确的转发流量&#xff0c;通常称为路由表 路由表主要包含如下 核心思想是根据目的 IP 地址来配置路由 目的网络&#xff1a;要去…