RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 996283
Accepted
Дмитрий
Дмитрий
Asked:2020-06-25 17:02:17 +0000 UTC2020-06-25 17:02:17 +0000 UTC 2020-06-25 17:02:17 +0000 UTC

备份 PostgreSQL 数据库管理系统

  • 772

有一个安装了 PostgreSQL DBMS 的服务器(linux suse),可以只使用 ssh 连接到数据库。需要自动将数据库备份到另一台远程服务器(linux centOS)。组织自动复制的最佳方式是什么?

linux
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Мелкий
    2020-06-25T18:08:45Z2020-06-25T18:08:45Z

    在 potgresql 备份问题中,有两种基本的可能性:

    逻辑备份

    常规实用程序pg_dump和pg_dumpall. 逻辑备份是将重新创建数据库的查询文本。由此得出:

    • 恢复缓慢。数据将很快被复制,但将在不知道此备份是什么的情况下构建索引和其他限制,并将检查限制的有效性
    • 只有在开始复制每个数据库时才能通过pg_dump(pg_dumpall调用pg_dump集群的每个数据库)进行恢复
    • 袖珍的。通常,数据库卷的很大一部分被索引占用。逻辑转储中的哪些仅由用于创建这些索引的命令表示。此外,文本压缩得很好。因此,逻辑转储很容易比数据库大小小 10 倍
    • 只能保存一些数据库,不能保存一些表
    • 文本格式plain- 只是请求的文本,即使使用文本编辑器也可以从中获取数据。
    • 格式custom,directory另一方面,您可以在多个流中并行恢复(directory并在多个流中拍摄) - 这减少了恢复时间。并且还可以从这些格式中恢复单个数据库对象,例如,只有一个表。

    pg_dump并且pg_dumpall可以通过网络工作。唯一的要求是备份机器上的实用程序版本必须与 DBMS 本身相同或更新。此外,对主要版本没有限制。pg_dump11.4 版可以有条件地从 9.3.12 版正确备份(通常在 7.0 版本之前)

    您还可以在不同版本的 postgresql 上恢复。

    物理备份

    另一种可能性是使用数据库的物理副本。pg_basebackup或其他实现。

    • 可以选择将数据库恢复到特定事务​​的时刻。这需要将基本备份带到所需的恢复点和连续的 WAL 存档
    • 此备份占用大量空间。如果您有兴趣恢复到任意时间点 (PitR),那么 WAL 归档文件会占用更多难以预测的容量
    • 它只是整个 postgresql 实例的副本。严格来说,此实例中的所有碱基都不能排除。并且体积正好等于底座的体积。
    • 恢复是简单的文件复制然后启动数据库。数据量方面有很多要复制的,但操作简单,多为大文件
    • 但是,恢复到任意时间点需要处理从 basebackup 开始到所需点的所有 WAL。而且它可能不会很快。
    • 只能使用基础的相同主要版本并且不低于相同的次要版本进行恢复

    它也可以毫无问题地通过网络工作。通常,除了备份之外,它们还会生成副本。


    然后数据库的所有者会考虑是否需要恢复到任意时间点,是否准备好备份如此大量的数据,或者例如每天的逻辑转储是否足够。然后你决定要保留多少份。

    您可以使用这两种方法,例如,在周一/周四删除基本备份的情况下制作一周深度的 WAL 存档,在周六制作pg_dump并存储一个逻辑转储,再保存六个月。

    直接设置选定的备份计划:

    • pg_dump 通常只从 cron 发送错误通知到邮件很方便。
    • 对于basebackup,手动编译正确的存档维护程序并不是那么简单,使用专门的系统是有意义的wal-g(如果你需要备份到非常简单S3)pgbackrest,,barman
    • 3

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    根据浏览器窗口的大小调整背景图案的大小

    • 2 个回答
  • Marko Smith

    理解for循环的执行逻辑

    • 1 个回答
  • Marko Smith

    复制动态数组时出错(C++)

    • 1 个回答
  • Marko Smith

    Or and If,elif,else 构造[重复]

    • 1 个回答
  • Marko Smith

    如何构建支持 x64 的 APK

    • 1 个回答
  • Marko Smith

    如何使按钮的输入宽度?

    • 2 个回答
  • Marko Smith

    如何显示对象变量的名称?

    • 3 个回答
  • Marko Smith

    如何循环一个函数?

    • 1 个回答
  • Marko Smith

    LOWORD 宏有什么作用?

    • 2 个回答
  • Marko Smith

    从字符串的开头删除直到并包括一个字符

    • 2 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5