使用命令行备份/还原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

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

相关推荐
lichenyang4533 小时前
Docker 学习笔记(五):Docker Compose,用一个 YAML 启动前端、后端和 MongoDB
docker
lichenyang4533 小时前
Docker 学习笔记(四):Dockerfile,把项目打成自己的镜像
docker·容器
lichenyang4533 小时前
Docker 学习笔记(三):Docker 网络、bridge、子网和容器互通
docker·容器
lichenyang4533 小时前
Docker 学习笔记(二):docker run 的参数到底在控制什么?
docker·容器
唐青枫2 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
小满8782 天前
5.Mysql事务隔离级别与锁机制
mysql
元Y亨H3 天前
技术笔记:MySQL 字符集排序规则与大小写敏感性问题解决方案
mysql
这个DBA有点耶4 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵4 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
SamDeepThinking4 天前
一条UPDATE语句在MySQL 8.0中到底加了几把锁?
后端·mysql·程序员