AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 19987
Accepted
Sean Preston
Sean Preston
Asked: 2009-06-05 11:19:31 +0800 CST2009-06-05 11:19:31 +0800 CST 2009-06-05 11:19:31 +0800 CST

从文件系统备份中恢复 PostgreSQL 数据库

  • 772

我有一个 PostgreSQL 8.3 数据目录备份。我需要将此备份中的数据库复制到新的 PostgreSQL 实例中。由于旧服务器的问题,我无法对数据库进行 pg_dump。

我已经弄清楚哪个目录是有问题的数据库的。例如,在 MySQL 中,您通常要做的就是关闭服务器,复制目录并重新启动它,然后数据库就可以使用了。现在这不适用于 PostgreSQL,我怀疑这是因为数据库未在 global/pg_database 文件中列出。这个文件似乎是在 PostgreSQL 启动时自动生成的,那么我如何告诉系统数据库在那里?

disaster-recovery postgresql
  • 1 1 个回答
  • 9918 Views

1 个回答

  • Voted
  1. Best Answer
    Bernd Haug
    2009-06-05T13:08:42+08:002009-06-05T13:08:42+08:00

    请注意,根据此处的文档,在 PostgreSQL 中,您的集群数据目录是一个独立的单元,无法可靠地部分恢复。

    您最好的希望是使用旧服务器的完整数据目录并在其上启动服务器,然后从您从那里获得的数据库转储中恢复:

    1. 获取一个适合新主机配置的 postgresql.conf (通过旧文件中的文件来定位自己 - 您在此处更改 - 和新数据目录)
    2. 找出旧安装的 PostgreSQL 超级用户的用户名 - 很可能是 postgres。
    3. 在新主机上创建此用户名(UNIX 用户),除非它已经存在。
    4. 将旧数据目录提供给该用户(chown),除非 uid 与旧服务器上的匹配。
    5. 在旧数据目录中配置 pg_hba.conf 以允许本地用户连接到相同的 postgres 用户名(这通常是默认设置,但请检查)。
    6. 以与旧数据目录的超级用户同名的 UNIX 用户身份运行旧数据库集群,例如用户 postgres:
      sudo -u postgres postgres -D old_data_directory
      
      

      或与苏:

      su postgres postgres -D old_data_directory
    7. 转储旧数据库,再次使用通常的用户名 postgres:
      sudo -u postgres pg_dump -p /path/to/socket/for/old/directory database_name > dump_file.sql
      
      

      类似于上面的 su 成为 postgres

    8. 使 dump_file.sql 适应新服务器的用户名等;在那里创建具有适当所有权的空数据库
    9. 将数据库扫描到新服务器中:
      sudo -u postgres psql -p /path/to/socket/for/new/directory new_database_name
      
      

      再次使用类似于上述的 su 获得 postgres 权限

    这应该让你做好准备,或者至少显示一条通往那里的好道路。

    • 16

相关问题

  • lvm+ext3 vs ext3 恢复

  • DPM 裸机还原

  • 镜像驱动器

  • IIS 6.0 (Windows Server 2003) 备份的最佳实践?

  • 当一切都爆炸时,你的清单是什么?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve