PostgreSQL数据库备份

news2025/7/23 16:31:24

文章目录

  • pg_dump 和 pg_dumpall
    • 使用 `pg_dump` 备份单个数据库
        • 示例
    • 使用 `pg_dumpall` 备份整个数据库集群
        • 基本用法
    • 恢复备份
        • 恢复 `pg_dump` 备份
        • 恢复 `pg_dumpall` 备份
  • Tips

pg_dump 和 pg_dumpall

在 PostgreSQL 中,pg_dump 和 pg_dumpall 是两个常用的备份工具,分别用于逻辑备份单个数据库和整个数据库集群。

检查pg_dumppg_dumpall命令是否可用

su - postgres
pg_dump --version
pg_dumpall --version

在这里插入图片描述


使用 pg_dump 备份单个数据库

pg_dump -U <用户名> -h <主机名> -p <端口号> -F <格式> -f <输出文件路径> <数据库名>

参数:

  • -U:指定数据库用户名。
  • -h:指定数据库主机地址(默认 localhost)。
  • -p:指定数据库端口(默认 5432)。
  • -F:指定备份格式:
    • plain(默认):生成 SQL 脚本文件。
    • c:自定义格式(支持压缩,需用 pg_restore 恢复)。
    • d:目录格式(支持并行备份)。
    • t:tar 格式。
  • -f:指定输出文件路径。
  • --schema-only:仅备份表结构(不包含数据)。
  • --data-only:仅备份数据(不包含表结构)。
  • -t <表名>:备份特定表。
  • -j <并行任务数>:并行备份(适用于大数据库)。
示例
  1. 备份整个数据库为 SQL 文件:

    pg_dump -U postgres -h localhost -p 5432 -F p -f /path/to/backup.sql mydb
    
    • -F p 表示输出为普通 SQL 文件。
    • mydb 是要备份的数据库名。
  2. 备份整个数据库为自定义格式(支持压缩):

    pg_dump -U postgres -h localhost -p 5432 -F c -f /path/to/backup.custom mydb
    
    • -F c 表示输出为自定义格式(需用 pg_restore 恢复)。
  3. 备份特定表:

    pg_dump -U postgres -h localhost -p 5432 -F p -t users -f /path/to/users_backup.sql mydb
    
    • -t users 表示仅备份 users 表。
  4. 仅备份表结构:

    pg_dump -U postgres -h localhost -p 5432 --schema-only -f /path/to/schema.sql mydb
    
  5. 仅备份数据(不包含表结构):

    pg_dump -U postgres -h localhost -p 5432 --data-only -f /path/to/data.sql mydb
    

使用 pg_dumpall 备份整个数据库集群

基本用法

pg_dumpall 用于备份整个 PostgreSQL 集群,包括所有数据库、角色(用户)、表空间等全局对象。

命令格式:

pg_dumpall -U <用户名> -h <主机名> -p <端口号> -f <输出文件路径> [选项]

参数:

  • -g:仅备份全局对象(角色、表空间等)。
  • -c:在备份中包含删除数据库的命令(用于恢复时清理旧数据)。
  • -v:启用详细模式(显示备份过程)。

示例

  1. 备份整个集群:

    pg_dumpall -U postgres -h localhost -p 5432 -f /path/to/cluster_backup.sql
    
    • 生成的 SQL 文件包含所有数据库、角色和表空间。
  2. 仅备份全局对象(角色、表空间):

    pg_dumpall -U postgres -h localhost -p 5432 -g -f /path/to/globals.sql
    
  3. 备份整个集群并包含清理命令:

    pg_dumpall -U postgres -h localhost -p 5432 -c -f /path/to/cluster_backup.sql
    

恢复备份

恢复 pg_dump 备份
  • SQL 文件恢复:

    psql -U <用户名> -h <主机名> -d <目标数据库> -f <备份文件路径>
    

    示例:

    psql -U postgres -h localhost -d mydb -f /path/to/backup.sql
    
  • 自定义格式恢复:

    pg_restore -U <用户名> -h <主机名> -d <目标数据库> <备份文件路径>
    

    示例:

    pg_restore -U postgres -h localhost -d mydb /path/to/backup.custom
    
恢复 pg_dumpall 备份
  • 恢复整个集群备份:

    psql -U postgres -h localhost -d postgres -f /path/to/cluster_backup.sql
    
    • 需以 postgres 用户连接到默认数据库(如 postgres),因为恢复过程中会创建其他数据库。
  • 恢复全局对象备份:

    psql -U postgres -h localhost -d postgres -f /path/to/globals.sql
    

Tips

  1. 权限要求:
    • pg_dump 需要对目标数据库有读取权限。
    • pg_dumpall 需要超级用户权限(以备份角色和表空间)。
  2. 备份格式选择:
    • 如果需要灵活的恢复选项(如选择性恢复表),建议使用自定义格式(-F c)。
    • 如果需要快速恢复,SQL 文件可能更直接。
  3. 并行备份:
    • 对大型数据库,使用 -j <并行任务数> 可加速备份(需 PostgreSQL 12+)。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2398371.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

js-day7

JS学习之旅-day7 1.事件流1.1 事件流与两个阶段说明1.2 事件捕获1.3 事件冒泡1.4 阻止1.5 解绑事件 2. 事件委托3. 其他事件3.1 页面加载事件3.2 页面滚动事件3.3 页面尺寸事件 4. 元素尺寸与位置 1.事件流 1.1 事件流与两个阶段说明 事件流指的是事件完整执行过程中的流动路…

解决Vditor加载Markdown网页很慢的问题(Vite+JS+Vditor)

1. 引言 在上一篇文章《使用Vditor将Markdown文档渲染成网页(ViteJSVditor)》中&#xff0c;详细介绍了通过Vditor将Markdown格式文档渲染成Web网页的过程&#xff0c;并且实现了图片格式居中以及图片源更换的功能。不过&#xff0c;笔者发现在加载这个渲染Markdown网页的时候…

鸿蒙5.0项目开发——横竖屏切换开发

横竖屏切换开发 【高心星出品】 文章目录 横竖屏切换开发运行效果窗口旋转配置module.json5的orientation字段调用窗口的setPreferredOrientation方法案例代码解析Index1页面代码&#xff1a;EntryAbility在module.json5的配置信息&#xff1a;Index页面的代码信息&#xff1…

Triton推理服务器部署YOLOv8(onnxruntime后端和TensorRT后端)

文章目录 一、Trition推理服务器基础知识1)推理服务器设计概述2)Trition推理服务器quickstart(1)创建模型仓库(Create a model Repository)(2)启动Triton (launching triton)并验证是否正常运行(3)发送推理请求(send a inference request)3)Trition推理服务器架…

TDengine 的 AI 应用实战——电力需求预测

作者&#xff1a; derekchen Demo数据集准备 我们使用公开的UTSD数据集里面的电力需求数据&#xff0c;作为预测算法的数据来源&#xff0c;基于历史数据预测未来若干小时的电力需求。数据集的采集频次为30分钟&#xff0c;单位与时间戳未提供。为了方便演示&#xff0c;按…

NLP学习路线图(二十一): 词向量可视化与分析

在自然语言处理&#xff08;NLP&#xff09;的世界里&#xff0c;词向量&#xff08;Word Embeddings&#xff09;犹如一场静默的革命。它将原本离散、难以捉摸的词语&#xff0c;转化为稠密、富含语义的连续向量&#xff0c;为机器理解语言铺平了道路。然而&#xff0c;这些向…

如何配置mvn镜像源为华为云

如何配置mvn镜像源为华为云 # 查找mvn 配置文件 mvn -X help:effective-settings | grep settings.xml# 配置mvn镜像源为华为云&#xff0c;/home/apache-maven-3.9.5/conf/settings.xml文件路径需要根据上一步中查询结果调整 cat > /home/apache-maven-3.9.5/conf/setting…

多模态大语言模型arxiv论文略读(105)

UnifiedMLLM: Enabling Unified Representation for Multi-modal Multi-tasks With Large Language Model ➡️ 论文标题&#xff1a;UnifiedMLLM: Enabling Unified Representation for Multi-modal Multi-tasks With Large Language Model ➡️ 论文作者&#xff1a;Zhaowei…

Pyhton中的命名空间包(Namespace Package)您了解吗?

在 Python 中&#xff0c;命名空间包&#xff08;Namespace Package&#xff09; 是一种特殊的包结构&#xff0c;它允许将模块分散在多个独立的目录中&#xff0c;但这些目录在逻辑上属于同一个包命名空间。命名空间包的核心特点是&#xff1a;没有 __init__.py 文件&#xff…

Azure DevOps Server 2022.2 补丁(Patch 5)

微软Azure DevOps Server的产品组在4月8日发布了2022.2 的第5个补丁。下载路径为&#xff1a;https://aka.ms/devops2022.2patch5 这个补丁的主要功能是修改了代理(Agent)二进制安装文件的下载路径&#xff1b;之前&#xff0c;微软使用这个CND(域名为vstsagentpackage.azuree…

手摸手还原vue3中reactive的get陷阱以及receiver的作用

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、实例是什么&#xff1f;二、new Prxoy三、实现代码1.引入代码2.读入数据 总结 前言 receiver不是为解决get陷阱而生&#xff0c;而是为解决Proxy中的this绑…

C++学习-入门到精通【13】标准库的容器和迭代器

C学习-入门到精通【13】标准库的容器和迭代器 目录 C学习-入门到精通【13】标准库的容器和迭代器一、标准模板库简介1.容器简介2.STL容器总览3.近容器4.STL容器的通用函数5.首类容器的通用typedef6.对容器元素的要求 二、迭代器简介1.使用istream_iterator输入&#xff0c;使用…

C# 面向对象特性

面向对象编程的三大基本特性是&#xff1a;封装、继承和多态。下面将详细介绍这三大特性在C#中的体现方式。 封装 定义&#xff1a;把对象的数据和操作代码组合在同一个结构中&#xff0c;这就是对象的封装性。 体现方式&#xff1a; 使用访问修饰符控制成员的可见性 通过属…

ElasticStack技术之logstash介绍

一、什么是Logstash Logstash 是 Elastic Stack&#xff08;ELK Stack&#xff09;中的一个开源数据处理管道工具&#xff0c;主要用于收集、解析、过滤和传输数据。它支持多种输入源&#xff0c;如文件、网络、数据库等&#xff0c;能够灵活地对数据进行处理&#xff0c;比如…

CI/CD 持续集成、持续交付、持续部署

CI/CD 是 持续集成&#xff08;Continuous Integration&#xff09; 和 持续交付/持续部署&#xff08;Continuous Delivery/Deployment&#xff09; 的缩写&#xff0c;代表现代软件开发中通过自动化流程快速、可靠地构建、测试和发布代码的实践。其核心目标是 减少人工干预、…

关于easyx头文件

一、窗口创建 &#xff08;1&#xff09;几种创建方式 #include<easyx.h>//easyx的头文件 #include<iostream> using namespace std;int main() {//创建一个500*500的窗口//参数为&#xff1a;长度&#xff0c;宽度&#xff0c;是否显示黑框&#xff08;无参为不…

django入门-orm数据库操作

一&#xff1a;下载数据库依赖项mysqlclient pip install mysqlclient 二&#xff1a;django配置文件配置数据库链接 路径&#xff1a;mysite2\mysite2\settings.py DATABASES {default: {ENGINE: django.db.backends.mysql,NAME: data, # 数据库名称USER: root, …

STM32外部中断(EXTI)以及旋转编码器的简介

一、外部中断机制概述 中断是指当主程序执行期间出现特定触发条件&#xff08;即中断源&#xff09;时&#xff0c;CPU将暂停当前任务&#xff0c;转而执行相应的中断服务程序&#xff08;ISR&#xff09;&#xff0c;待处理完成后恢复原程序的运行流程。该机制通过事件驱动…

双擎驱动:华为云数字人与DeepSeek大模型的智能交互升级方案

一、技术融合概述 华为云数字人 华为云数字人&#xff0c;全称&#xff1a;数字内容生产线 MetaStudio。数字内容生产线&#xff0c;提供数字人视频制作、视频直播、智能交互、企业代言等多种服务能力&#xff0c;使能千行百业降本增效。另外&#xff0c;数字内容生产线&#…

实验设计与分析(第6版,Montgomery)第5章析因设计引导5.7节思考题5.5 R语言解题

本文是实验设计与分析&#xff08;第6版&#xff0c;Montgomery著&#xff0c;傅珏生译) 第5章析因设计引导5.7节思考题5.5 R语言解题。主要涉及方差分析&#xff0c;正态假设检验&#xff0c;残差分析&#xff0c;交互作用图。 dataframe <-data.frame( wrapc(17,20,12,9,…