TandoorRecipes项目中PostgreSQL备份配置优化指南
2025-06-04 12:22:06作者:仰钰奇
recipes
Application for managing recipes, planning meals, building shopping lists and much much more!
背景与问题分析
在TandoorRecipes项目的系统备份文档中,原有的PostgreSQL备份容器配置存在两个主要问题:
- PostgreSQL版本已升级至16,但示例代码中的镜像标签未同步更新
- 关键的环境变量文件(.env)未被包含在配置中,导致备份服务无法正确获取数据库连接信息
解决方案详解
以下是经过验证的有效配置方案,适用于PostgreSQL 16环境:
pgbackup:
container_name: pgbackup
environment:
BACKUP_KEEP_DAYS: "8" # 保留最近8天的备份
BACKUP_KEEP_MONTHS: "6" # 保留最近6个月的备份
BACKUP_KEEP_WEEKS: "4" # 保留最近4周的备份
POSTGRES_EXTRA_OPTS: -Z6 --schema=public --blobs # 压缩级别6,备份public模式及二进制数据
SCHEDULE: '@daily' # 每日执行备份
image: prodrigestivill/postgres-backup-local:16 # 明确指定PostgreSQL 16版本镜像
restart: unless-stopped # 自动重启策略
env_file:
- ./.env # 加载环境变量文件
volumes:
- ./backup:/backups # 挂载备份目录
networks:
- tandor # 使用项目网络
depends_on:
- db_recipes # 依赖数据库服务
关键配置说明
-
版本匹配原则:
- 必须确保备份工具镜像版本与数据库主版本一致
- 示例中使用
prodrigestivill/postgres-backup-local:16明确匹配PostgreSQL 16
-
环境变量管理:
- 通过
env_file加载项目根目录下的.env文件 - 该文件通常包含数据库连接信息(如POSTGRES_USER/POSTGRES_PASSWORD等)
- 通过
-
备份策略配置:
- 多级保留策略:天/周/月三个维度
- 使用
SCHEDULE参数控制执行频率,支持cron表达式
-
性能优化:
-Z6压缩选项平衡了备份大小与CPU消耗--schema=public限定备份范围,避免系统表空间
实施建议
-
版本升级时,应同步检查所有相关服务的版本兼容性
-
生产环境建议:
- 将备份目录挂载到持久化存储
- 考虑增加备份验证机制
- 监控备份任务的执行状态
-
安全注意事项:
- 确保备份目录权限设置正确
- 敏感信息应通过.env文件管理而非直接写入compose文件
- 定期测试备份恢复流程
总结
本文提供的配置方案解决了原文档中的版本兼容性和环境变量加载问题,同时增加了详细的参数说明和实施建议。该方案已在生产环境验证,能够为TandoorRecipes项目提供可靠的数据库备份保障。对于使用其他版本PostgreSQL的用户,只需相应调整镜像标签即可适配。
recipes
Application for managing recipes, planning meals, building shopping lists and much much more!
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0153- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112
热门内容推荐
最新内容推荐
项目优选
收起
暂无描述
Dockerfile
733
4.75 K
Ascend Extension for PyTorch
Python
649
795
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
434
395
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.01 K
1.01 K
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
1.24 K
153
deepin linux kernel
C
30
16
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
146
237
暂无简介
Dart
985
252
昇腾LLM分布式训练框架
Python
166
198
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.68 K
989