ECS Docker Compose数据卷备份与恢复操作指南
这是一份 ECS 上维护 Docker Compose 基础服务的操作记录,场景不算复杂:一个小型业务环境,用 Compose 跑着 app、mysql、redis 和一个反向袋里。说白了,就是日常维护时那些绕不开的活儿——数据库备份、缓存检查、镜像版本锁死、升级前预热,外加万一翻车怎么回滚。

几个维护目标拎一下:
- 固定数据库和缓存的镜像版本,别让“latest”哪天给坑了。
- 确认 MySQL 数据卷的具体位置,别等到备份时才发现路径不对。
- 做一次逻辑备份,并且真的恢复验证一遍——光备份不验证等于没备份。
- 升级前预拉镜像,别在窗口期里干等下载,那段时间能把人急死。
1. 检查最终配置
先跑一把 docker compose config,确认当前生效的 compose 配置长什么样。尤其是 MySQL 服务,建议把命名卷写明确,不要依赖默认的匿名卷,不然后面 volume 名称乱得你认不出来。
services:
mysql:
image: docker.1ms.run/mysql:8.4
environment:
MYSQL_ROOT_PASSWORD: change-me
MYSQL_DATABASE: app
volumes:
- mysql-data:/var/lib/mysql
volumes:
mysql-data:
2. 检查 volume
用 docker volume ls 看看有哪些卷,再用 docker volume inspect 项目名_mysql-data 确认挂载点。这里有个常见坑:如果项目目录改过,Compose 项目前缀会跟着变,新卷的名字就变了,旧数据可能就丢了。所以这一步别跳过。
3. 备份 MySQL
用 docker compose exec 执行 mysqldump,把备份导出来:
docker compose exec mysql sh -c 'mysqldump -uroot -p"$MYSQL_ROOT_PASSWORD" app' > mysql-app.sql
光备份不够,得恢复验证。跑一遍:
cat mysql-app.sql | docker compose exec -T mysql sh -c 'mysql -uroot -p"$MYSQL_ROOT_PASSWORD" app'
要是恢复失败,别急着推进升级步骤——先排查用户权限、密码是否一致、数据库名、字符集、MySQL 版本差异这些因素。恢复不通过,升级就是赌运气。
4. 检查 Redis
Redis 的角色决定了处理方式。如果只是缓存,重建一下影响有限,重启就完事。但如果它承载着队列或者会话,那就必须挂载 /data 卷,并确认持久化策略——比如开启 AOF:
services:
redis:
image: docker.1ms.run/redis:7
command: ["redis-server", "--appendonly", "yes"]
volumes:
- redis-data:/data
另外别忘了一件事:云服务器上的安全组和端口暴露。Redis 默认端口 6379,千万别直接暴露到公网上,不然就是给黑客送大礼。
5. 预拉镜像
升级前先把目标镜像拉到本地,这样升级过程中就不需要联网下载了:
docker pull docker.1ms.run/mysql:8.4
docker pull docker.1ms.run/redis:7
docker pull docker.1ms.run/nginx:1.27-alpine
确认预拉成功后,再走升级流程:
docker compose pull
docker compose up -d
6. 回滚准备
动手维护之前,把下面这些东西记下来,最好是写成文档或者贴到笔记里:
- 当前使用的旧镜像 tag。
- 此刻生效的
compose.yaml内容(可以 git 提交一份)。 - 数据库备份文件(就是刚才导出的 .sql)。
- 关键 volume 的名称(比如 mysql-data, redis-data)。
- 恢复验证的结果,明确写上“验证通过”还是“失败”以及原因。
小结
在 ECS 上用 Compose 跑服务,说白了就是把镜像、容器、数据卷这三件事分开处理。容器随便重建,镜像随时重拉,但数据卷必须先备份、再验证恢复结果,才能放心操作。维护窗口的精力应该花在升级本身,而不是临时抱佛脚排查备份能不能用。提前做好回滚预案,翻车也不慌。
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
RAG四标融合企业知识资产体系四库协同GEO优化实践
生成式AI正在彻底改写信息检索的底层逻辑。传统SEO依赖关键词堆砌和外链建设的策略,在大模型的内容采信规则下已经基本失效。取而代之的,是生成式引擎优化(GEO)。它不再关注外链数量,而是重点衡量你的知识是否结构化、证据链是否坚实、信源是否可靠——这些维度才是RAG(检索增强生成)架构真正看重的核心指
一个普通上班人分享WorkBuddy使用心得与真实体验
前言 最近我开始使用WorkBuddy——这是腾讯推出的一款AI办公工作台。差不多用了一周时间,趁印象还新鲜,把真实的使用感受记录下来,给还在犹豫的朋友做个参考。不吹不黑,只说实际体验。 初印象:不只是聊天机器人 之前用过不少AI工具,大多数就是个对话框,你问它答,答完就结束了。WorkBuddy不
AI幻觉变真功能实战教程:App Inventor 2视频录制拓展一周开发实录
先讲一个颇具戏剧性的开端。 这件事的开端颇显荒诞——有用户前来咨询,称AI Pro版的介绍中提到我们有一款“视频录制拓展”。团队全体成员都感到困惑,翻遍产品列表,发现根本不存在该组件。AI那种“一本正经胡说八道”的能力,这次确实让我们陷入尴尬。 按常理,此事到此便可结束——一句“抱歉,暂时没有这个拓
别再混淆OLAP和SQL-on-Hadoop两者查询本质不同
OLAP和SQL-on-Hadoop虽都使用SQL查询数据,但本质不同。SQL-on-Hadoop负责海量数据批量计算与ETL,查询速度秒级至分钟级;OLAP通过预聚合实现毫秒级多维分析,适合BI报表。两者在数据平台分工协作,前者是后厨加工,后者是前台快速服务。
GEO优化深度解析:AI偏好FAQ还是长文内容?
在GEO优化中,AI对内容形式无统一偏好:FAQ在简单查询中引用率41%,长文在复杂查询中达58%。内容应基于用户意图选择形式,FAQ适配简单事实类问题,长文建立主题权威,两者互补而非替代。
- 日榜
- 周榜
- 月榜
相关攻略
2026-07-01 17:42
2026-07-01 17:42
2026-07-01 17:41
2026-07-01 17:41
2026-07-01 17:41
2026-07-01 17:41
2026-07-01 17:41
2026-07-01 17:41
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

