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

Docker Compose 数据卷备份恢复:MySQL/Postgres/Redis 升级前检查清单

本文记录一套 Docker Compose 基础服务升级前的检查流程,适用于开发环境、小团队测试机、自托管服务和轻量业务系统。核心对象是 MySQL、Postgres、Redis 这类有状态服务。

目标不是讲 Docker Compose 入门,而是避免这类事故:

  • Compose 项目换目录后,数据库像新装的一样。
  • 执行docker compose down -v后,命名卷也被移除。
  • 旧环境用了匿名卷,新环境没有挂回旧数据。
  • MySQL/Postgres 有备份文件,但没有恢复演练。
  • Redis 默认当缓存用,实际业务却依赖它的状态。

1. 先分清三类对象

对象典型命令升级时怎么处理
镜像docker pull固定 tag,提前预拉
容器docker compose up -d可重建,检查环境变量和端口
数据卷docker volume inspect先备份,再恢复验证

数据库容器最重要的不是容器 ID,而是数据目录背后的 volume。

2. down 和 down -v 的区别

docker compose down会停止并移除容器、网络等资源,但默认不会删除命名卷。带上-v后,会移除 Compose 文件中声明的命名卷和匿名卷。

建议维护脚本里不要随手写:

dockercompose down-v

除非你确认这是一次彻底销毁环境,并且数据已经备份、恢复也验证过。

3. 推荐写稳定命名卷

Postgres 示例:

services:db:image:docker.1ms.run/postgres:16environment:POSTGRES_USER:appPOSTGRES_PASSWORD:change-mePOSTGRES_DB:appvolumes:-db-data:/var/lib/postgresql/datavolumes:db-data:

MySQL 示例:

services:mysql:image:docker.1ms.run/mysql:8.4environment:MYSQL_ROOT_PASSWORD:change-meMYSQL_DATABASE:appvolumes:-mysql-data:/var/lib/mysqlvolumes:mysql-data:

Redis 示例:

services:redis:image:docker.1ms.run/redis:7command:["redis-server","--appendonly","yes"]volumes:-redis-data:/datavolumes:redis-data:

这里的重点是:数据库目录必须挂到稳定的命名卷或明确路径,不要靠匿名卷碰运气。

4. 升级前检查命令

查看最终配置:

dockercompose config

查看当前卷:

dockervolumels

查看卷详情:

dockervolume inspect 项目名_db-data

查看服务使用的挂载:

dockerinspect 容器名--format'{{json .Mounts}}'

如果看到数据库写在匿名卷里,先停下来处理迁移,不要直接升级。

5. MySQL 备份和恢复

备份:

dockercomposeexecdbsh-c'mysqldump -uroot -p"$MYSQL_ROOT_PASSWORD" app'>mysql-app.sql

恢复验证:

catmysql-app.sql|dockercomposeexec-Tdbsh-c'mysql -uroot -p"$MYSQL_ROOT_PASSWORD" app'

注意点:

  • 不要只备份 volume tar 包就结束。
  • 逻辑备份更容易跨环境验证。
  • 大版本升级前先在临时环境导入一次。

6. Postgres 备份和恢复

备份:

dockercomposeexec-Tdb pg_dump-Uapp app>pg-app.sql

恢复验证:

catpg-app.sql|dockercomposeexec-Tdb psql-Uapp app

注意点:

  • POSTGRES_USERPOSTGRES_DBPOSTGRES_PASSWORD要和恢复命令一致。
  • 跨大版本升级时,先看官方镜像关于PGDATA和数据目录的说明。
  • 生产大库需要更严肃的备份方案,本文只覆盖 Compose 小环境和轻量维护。

7. Redis 要先判断是不是状态服务

Redis 如果只是缓存,重建影响可能可控。如果承载队列、会话、任务状态,就要明确持久化策略。

建议检查:

dockercomposeexecredis redis-cli CONFIG GET appendonlydockercomposeexecredis redis-cli CONFIG GETdir

需要持久化时,至少确认:

  • /data已挂载到稳定卷。
  • RDB 或 AOF 策略符合业务预期。
  • 没有把无密码 Redis 暴露到公网。

8. 镜像预检放在恢复演练之后

维护窗口前可以先拉固定版本镜像:

dockerpull docker.1ms.run/postgres:16dockerpull docker.1ms.run/mysql:8.4dockerpull docker.1ms.run/redis:7dockerpull docker.1ms.run/adminer:latest

毫秒镜像(1ms.run)在这里解决的是镜像预检问题:数据库镜像、管理工具镜像和业务基础镜像别到维护窗口才开始拉。它不替代备份,也不替代恢复验证。

9. 最终检查表

步骤检查项通过标准
1docker compose config卷、端口、环境变量清楚
2docker volume ls关键数据卷有稳定名字
3docker volume inspect挂载点和项目标签确认
4逻辑备份MySQL/Postgres 有可迁移备份
5恢复演练临时环境能导入
6Redis 策略明确缓存还是状态服务
7镜像预拉固定 tag 能拉取
8回滚记录旧镜像 tag 和旧备份可用

总结

Docker Compose 让容器重建变得很轻,但有状态服务不能按无状态服务处理。升级前先确认数据卷、备份、恢复演练,再处理镜像预检和服务重启。这个顺序不复杂,但能避开很多低级事故。

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

相关文章:

  • BSPHP系统未授权访问漏洞实战剖析:从成因到防护与应急响应
  • 遗传算法实战:N皇后问题的Python实现与调试精要
  • 计算机毕业设计之基于深度学习的单尺度乳腺组织病理图像分类算法
  • LeetCode刷题 day26
  • 工业级机器学习系统:总体架构设计
  • 施耐德 FLM CVE-2024-2658 漏洞攻击链与工控终端防护研究
  • ngx_http_autoindex_handler
  • 计算机Java毕设实战-基于 Java Web 的乡村茶园文化展示推广系统的设计与实现 基于 Java Web 的茶农互动交流资讯平台【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 安全触边是什么?主要具有哪些防撞功能与应用?
  • 为什么癌前病变进展研究需要空间单细胞蛋白组?
  • 山西快速上门美缝
  • 博学谷ai大模型就业班第八期
  • GitHub数学公式终极指南:MathJax插件让你的技术文档更专业
  • 计算机Java毕设实战-基于 SpringBoot 的宠物疫苗接种溯源管理系统的设计与实现 基于 SpringBoot 的宠物医院医疗设备运维管【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • pSLC 是智商税还是真技术?
  • Vibe Coding新手实战:做一个黑白棋游戏
  • 技术速递|基于 Microsoft Agent Framework 的 Agentic 开发“黄金三角”
  • Python和.NET交互-与最新DeepSeekV3.2大模型对话
  • 海外APP定制开发,租车类案例评估报价
  • YOLOv8注意力机制改进与Transformer融合策略:提升目标检测全局上下文感知能力
  • 终极NomNom存档编辑器:轻松定制你的《无人深空》游戏体验
  • Samsung KLM8G1GEUF-B04P引脚功能与封装:车规级eMMC存储芯片数据手册
  • 博图桌面静态计数机,数字化仓储解决方案
  • 微信聊天记录误删怎么办?官方完整恢复教程整理
  • 开局一台虚拟机,我在运维世界练级之安装Linux系统
  • 安装git
  • 2026 AI外呼机器人厂商测评及盘点:AI 电话外呼系统哪家更适合中小企业?
  • ai_hot_news_20260630
  • 2026跨系统自动化工具盘点:从RPA到AI Agent主流方案全解析
  • SaaS多租户商城源码-Joolun pro旗舰版的核心竞争力有哪些?