迁移PostgreSQL数据库教程

离线迁移PostgreSQL数据库

这个教程将指导您如何使用pg_dumppg_restore命令,通过离线的方式,将您的PostgreSQL数据库从一台服务器迁移到另一台。

在旧服务器上备份

在您的旧服务器上,打开终端或命令行,执行以下两个命令。

这个命令会将单个数据库,如 -d 指定的名为 postgres 的数据库进行备份。

Bash 复制代码
pg_dump -h sbp-jefk8patl3pot31s.supabase.opentrust.net -U postgres -d postgres -F c -b -f postgres_db.dump

参数

  • -F p -f backup.sql # plain SQL
  • -F c -f backup.dump # custom格式
  • -U 指定用户名
  • -f 指定的备份文件名

在执行以上命令时,系统会提示您输入 postgres 用户的密码。

查看备份下来的数据(可选)

如果您想确认一下备份文件里是否包含了您想要的数据,比如 shops 表,您可以在旧服务器上执行下面的命令:

Bash 复制代码
pg_restore -l postgres.dump | grep shops

如果 shops 表在备份文件里,这个命令会把它显示出来。


在新服务器上恢复

在新服务器上,打开终端或命令行。

现在,把 postgres.dump 文件里的数据,恢复到您刚刚创建的空数据库里。

Bash 复制代码
pg_restore  -h sbp-jefk8patl3pot31s.supabase.opentrust.net  -U postgres -d postgres postgres.dump

在执行以上命令时,系统同样会提示您输入 postgres 用户的密码。


在线迁移PostgreSQL数据库

知道了前面,这可以直接执行新的。从一条立即迁移到另一台上。

shell 复制代码
pg_dump -h sbp-jefk8patl3pot31s.supabase.opentrust.net -U postgres -d postgres -F c | pg_restore -h 目标主机 -U postgres -d 目标数据库 --clean --if-exists
相关推荐
程序员晓琪2 分钟前
约定大于配置:基于 Java 包名自动生成 API 版本路由的最佳实践
java·spring boot·后端
银卡11 分钟前
RAG Embedding 模型选型
后端
用户5598224812212 分钟前
Claude Code + DeepSeek V4 Pro 说"不行"时,别信
后端
leeyi39 分钟前
Manus Agent:一个全能 AI,和一支研究团队
后端·aigc·agent
东坡白菜43 分钟前
破局全栈:前端开发的Java入门实战记录—JPA(2)
java·后端
代码丰44 分钟前
RAG 系统如何实现全链路追踪:AOP 埋点与流式调用追踪实践
后端
小码编匠1 小时前
C# 工控上位机必备:数据转换工具类与十个核心模块
后端·c#·.net
神奇小汤圆2 小时前
一文读懂 OpenAI Codex 源码的原理、架构与未来
后端
道友可好2 小时前
AI 是最好的混乱放大器:代码熵管理实战
前端·人工智能·后端
掘金者阿豪3 小时前
写了很多内容后,我还是决定给自己搭一个Typecho博客
后端