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

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

相关推荐
User_芊芊君子2 小时前
从零入门!MySQL 约束、范式设计与联合查询核心精讲
数据库·人工智能·mysql
张青贤2 小时前
Docker Remote 未授权访问漏洞修复方法
运维·docker·容器
重生之我是Java开发战士2 小时前
【MySQL】视图:简化查询、保障安全的虚拟表
数据库·mysql
2301_808414382 小时前
MySQL的基础认识
数据库·mysql
小夏子_riotous2 小时前
Docker学习路径——10、Docker Compose 一站式编排:从入门到生产级部署
linux·运维·服务器·docker·容器·centos·云计算
小菜同学爱学习2 小时前
兜底保障!MySQL运维实战与常见问题排查全解析
运维·mysql·adb
smallcelebration2 小时前
132 docker入门学习
学习·docker·容器
A-刘晨阳2 小时前
K8s 之 Ingress 及 Ingress Controller
云原生·容器·kubernetes·负载均衡·ingress
HalvmånEver2 小时前
MySQL表的查询(二)
linux·数据库·学习·mysql