使用命令行备份/还原docker运行的数据库 (MySQL、PostgreSQL)

备份MySQL数据库,如果有图形界面操作肯定很方便,那就使用图形界面进行备份与还原;若是使用的Linux系统,没有图形界面,可以试试如下方式:

1、备份数据库

一、MySQL(Docker)备份与恢复

假设容器名:mysql;数据库名:biz_db


✅ 1. 备份(推荐方式:docker exec)

✔ 标准备份

bash 复制代码
docker exec mysql \
  mysqldump -u root -p'数据库密码' \
  --single-transaction --quick \
  biz_db > /home/soft/mysql/backup/biz_db_$(date +%F).sql

docker exec mysql \

mysqldump -u root -p'数据库密码' \

--single-transaction --quick \

数据库名称 > /位置/biz_db_$(date +%F).sql


✔ 压缩备份(强烈推荐)

bash 复制代码
docker exec mysql \
  mysqldump -u root -p'数据库密码' biz_db \
  | gzip > /home/soft/mysql/biz_db_bak.sql.gz

docker exec mysql \

mysqldump -u root -p'数据库密码' 数据库名称 \

| gzip > /位置/biz_db_bak.sql.gz


✔ 备份结构 + 存储过程(生产建议)

bash 复制代码
docker exec mysql \
  mysqldump -u root -p'数据库密码' \
  --routines --triggers --events \
  --single-transaction biz_db \
  | gzip > /home/soft/mysql/backup/biz_db_full.sql.gz

docker exec mysql \

mysqldump -u root -p'数据库密码' \

--routines --triggers --events \

--single-transaction 数据库名称 \

| gzip > /backup/biz_db_full.sql.gz


⚠️ 注意(生产关键点)

  • 不要写成 -p tbea@xxx(中间不能有空格)
  • 容器内执行比宿主机直连更稳
  • 建议不要用 root → 用 backup 用户

✅ 2. 恢复

✔ 从 SQL 恢复

bash 复制代码
cat /home/soft/mysql/backup/biz_db.sql | docker exec -i mysql \
  mysql -u root -p'数据库密码' biz_db

cat /backup/biz_db.sql | docker exec -i mysql \

mysql -u root -p'数据库密码' 数据库名称


✔ 从压缩恢复

bash 复制代码
gunzip < /home/soft/mysql/backup/biz_db.sql.gz | docker exec -i mysql \
  mysql -u root -p'数据库密码' biz_db

gunzip < /backup/biz_db.sql.gz | docker exec -i mysql \

mysql -u root -p'数据库密码' 数据库名称


🚀 3. 直接恢复到"新容器"(非常实用)

bash 复制代码
docker run -d --name mysql-new \
  -e MYSQL_ROOT_PASSWORD=数据库密码 \
  mysql:8.0

# 等待启动后恢复
gunzip < biz_db.sql.gz | docker exec -i mysql-new \
  mysql -uroot -p数据库密码 biz_db

docker run -d --name mysql-new \

-e MYSQL_ROOT_PASSWORD=数据库密码 \

mysql:8.0

等待启动后恢复

gunzip < biz_db.sql.gz | docker exec -i mysql-new \

mysql -uroot -p'数据库密码' 数据库名称


二、PostgreSQL(Docker)备份与恢复

假设容器名:postgres;数据库名:biz_db

✅ 1. 备份

✔ 标准备份(推荐)

bash 复制代码
docker exec postgres \
  pg_dump -U postgres -d biz_db \
  -F c -f /tmp/biz_db.dump

docker exec postgres \

pg_dump -U postgres -d biz_db \

-F c -f /tmp/biz_db.dump

然后拷贝出来:

bash 复制代码
docker cp postgres:/tmp/biz_db.dump /backup/

✔ 一步到位(宿主机直接生成)

bash 复制代码
docker exec postgres \
  pg_dump -U postgres biz_db \
  > /backup/biz_db.sql

docker exec postgres \

pg_dump -U postgres biz_db \

> /backup/biz_db.sql


✔ 压缩备份

bash 复制代码
docker exec postgres \
  pg_dump -U postgres biz_db \
  | gzip > /backup/biz_db.sql.gz

docker exec postgres \

pg_dump -U postgres biz_db \

| gzip > /backup/biz_db.sql.gz


✅ 2. 恢复


✔ SQL恢复

bash 复制代码
cat /backup/biz_db.sql | docker exec -i postgres \
  psql -U postgres -d biz_db

✔ dump格式恢复(推荐)

bash 复制代码
cat /backup/biz_db.dump | docker exec -i postgres \
  pg_restore -U postgres -d biz_db

✔ 压缩恢复

bash 复制代码
gunzip < /backup/biz_db.sql.gz | docker exec -i postgres \
  psql -U postgres -d biz_db

这样就可以实现数据库的备份还原操作了!

相关推荐
todoitbo10 小时前
从 MySQL 到 KingbaseES:Database、Schema、User 一次讲透
数据库·mysql·国产数据库·kingbasees
梦想的颜色10 小时前
硬核|Docker从入门到精通:镜像构建、仓库推送、Compose编排、生产部署全攻略
运维·服务器·docker·容器·部署·环境·镜像
千云10 小时前
100w大表0停机回滚:我们为什么放弃Undo Log,选择表名切换?
数据库·后端·mysql
SXJR10 小时前
使用docker 部署向量数据库Milvus
数据库·docker·容器·milvus·向量数据库
AC赳赳老秦10 小时前
用 OpenClaw 制定技术学习计划:根据目标岗位自动生成学习路线、推荐学习资源
开发语言·c++·人工智能·python·mysql·php·openclaw
qq_4523962310 小时前
第二篇:《K8s 集群搭建:Minikube、kubeadm、Kind 对比与实操》
容器·kubernetes·kind
前进的李工10 小时前
MySQL性能优化:索引与子查询实战技巧
数据库·sql·mysql·性能优化
段ヤシ.11 小时前
回顾Java知识点,面试题汇总Day13:数据库MySQL(持续更新)
java·数据库·mysql
jingqiulyue11 小时前
docker run出现exited或者不断restart怎么办
docker·容器
小哈里11 小时前
【K8S】OCI标准下的企业级镜像治理:Harbor+Skopeo+Trivy 最佳实践
云原生·容器·kubernetes·harbor·镜像·skopen