当前位置: 首页 > news >正文

PostgreSQL 跑在 Docker 里怎么备份?恢复成功才算备份成功

PostgreSQL 跑在 Docker 里怎么备份?恢复成功才算备份成功

很多自托管应用背后都有 PostgreSQL:书签、财务、知识库、自动化平台。最危险的备份方式,是只把postgres_data目录压缩走,等换机器恢复时才发现版本、权限、WAL 状态都对不上。本文给一套适合个人服务器的 Docker PostgreSQL 备份恢复流程。

备份到底要备什么

最小可用备份包括:数据库逻辑导出、compose.yaml.env、应用上传目录。数据库导出负责恢复数据表,配置文件负责恢复连接信息,上传目录负责恢复附件。只备其中一个都不完整。

逻辑导出适合个人和小团队,因为它更容易跨机器、跨小版本恢复。体量很大的数据库才需要额外设计物理备份、WAL 归档和备机。

服务器规格建议

PostgreSQL 对内存和磁盘稳定性比较敏感。轻量应用可以 2 核 4G 起步,多个应用共用一套数据库建议 4 核 8G。备份时会产生压缩文件和临时 I/O,系统盘太小会让备份脚本自己把机器写满。

我会把 PostgreSQL 和两三个中小型自托管应用放在雨云服务器 rainyun-com的 2 核 4G 或 4 核 8G 机型上,重点关注磁盘和备份空间。注册填优惠码2026off领 5折,省下来的预算优先给快照和异地备份,而不是只看 CPU。

Compose 示例

下面只是通用示例,发布前要按具体应用官方文档确认数据库版本和环境变量:

services:postgres:image:postgres:16restart:unless-stoppedenvironment:POSTGRES_DB:appPOSTGRES_USER:appPOSTGRES_PASSWORD:change-this-passwordvolumes:-./postgres-data:/var/lib/postgresql/data

不要把数据库端口直接映射到公网。应用和数据库在同一个 Compose 网络里通信即可,除非你明确需要远程管理,并且已经做好防火墙和访问控制。

备份脚本怎么写

可以用pg_dump从容器里导出,再压缩保存:

#!/usr/bin/env bashset-euopipefailAPP_DIR=/opt/myappBACKUP_DIR=/opt/backups/myappSTAMP=$(date+%F-%H%M)mkdir-p"$BACKUP_DIR"cd"$APP_DIR"dockercomposeexec-Tpostgres pg_dump-Uapp-dapp\|gzip>"$BACKUP_DIR/postgres-$STAMP.sql.gz"tar-czf"$BACKUP_DIR/config-$STAMP.tar.gz"compose.yaml .env uploadsfind"$BACKUP_DIR"-typef-mtime+14-delete

如果数据敏感,备份文件要加密后再同步到异地,不要直接放公开网盘。至少每月做一次恢复演练,不然你只能证明“脚本会生成文件”,不能证明“数据能回来”。

恢复演练

恢复不要直接在生产机上练。开一台临时机器,复制备份文件,启动同版本 PostgreSQL,再导入:

gzip-dcpostgres-2026-06-10-0300.sql.gz\|dockercomposeexec-Tpostgres psql-Uapp-dapp

验证标准不是命令退出 0,而是应用能登录、列表能打开、附件能下载、关键数据数量大致对得上。演练完成后销毁临时机器,避免测试环境继续暴露。

常见问题

pg_dump报认证失败,多半是用户名、数据库名或环境变量和实际不一致。导入时报对象已存在,说明目标库不是空库。恢复后中文乱码,通常是客户端环境或导入方式有问题,优先保持 PostgreSQL 默认 UTF-8。

如果数据库很大,不要在业务高峰压缩备份。可以先降低压缩级别,或者把备份放到业务低谷执行。

总结

PostgreSQL 的备份不能只看有没有文件,要看能不能在另一台机器恢复。逻辑导出、配置备份、异地保存、恢复演练,四步缺一不可。

如果你想低成本做恢复演练,可以临时开一台雨云服务器 rainyun-com做测试机,注册填优惠码2026off领 5折。把恢复流程跑通后,再处理生产环境会踏实很多。

http://www.jsqmd.com/news/1021763/

相关文章:

  • QR分解:机器学习中被低估的数值稳定器
  • 2026年四川经营许可证代办机构服务能力观察:本土化深耕与全链条服务成行业趋势 - 优质品牌商家
  • 提升终端工作流:fzf-tab-completion与Git命令的完美结合
  • 个人GPU部署LLM:68个可运行模型的显存、量化与框架实战指南
  • Monorepo本质:语义一致性治理与规模化协作降熵
  • 实力强的花木枝叶粉碎机生产厂推荐与费用 - mypinpai
  • Python空列表的底层原理与工程实践指南
  • 【招聘】人才地图①:招聘的最高境界,不是找人,是“知道人在哪里“
  • 5步上手:通达信缠论插件ChanlunX实现智能中枢绘制与笔段识别
  • 【招聘】人才地图④:五种Mapping方法——把散乱的信息,变成驱动决策的人才情报
  • 彻底卸载Ansys许可证:FlexNet三层架构清理与疑难排解指南
  • AWS S3 Sync 生产级同步原理与避坑指南
  • 靠谱的电力工具检测中心怎么选?弘宇电力检测口碑如何? - mypinpai
  • 文档操作系统:从模板到PDF的自动化工程化实践
  • 如何选择最佳句子相似度模型:jeffding/sentence_similarity_semantic_search-openmind vs 传统方法的终极对比指南
  • 目标检测算法Yolov5训练反光衣数据集模型 建立基于深度学习yolov5反光衣的检测
  • 上三角数字三角形:循环嵌套与格式化输出的核心实现与调试指南
  • Codex:面向非技术人的零代码AI工作流引擎
  • Unity透明窗口技术:如何让应用突破窗口边界?
  • Gemini 3.1 Flash语音原生架构解析:突破400ms实时交互拐点
  • 电力配电安装步骤?电力配电安装公司
  • 非技术人员如何看懂AI编程全流程:从原型到上线的协作飞轮
  • Claude Opus 4.7 MAX:编程与视觉融合的工程化临界点
  • 探讨快递箱批量定制的性价比,哪家更划算? - mypinpai
  • 【读书笔记】《OKR工作法》
  • RHEL 9 上 ROS 2 Jazzy 二进制安装实战指南
  • 探索未来文件管理:ownCloud Infinite Scale
  • 【课程设计/毕业设计】SpringBoot 赋能的校园图书馆座位运维管理系统 面向师生的图书馆智能占座预约系统设计实现【附源码、数据库、万字文档】
  • SAP Cloud Integration 租户授权设计,从用户、用户组到技术用户的一套治理思路
  • Java 17 核心特性解析与生产环境迁移实战指南