当前位置:   article > 正文

docker mysql 备份与还原_docker mysql 还原sql

docker mysql 还原sql

Docker MySql 备份与还原

1、docker直连mysql接数据库

 docker exec -it mysql5 mysql -uroot -proot
  • 1

2、所有数据库

  • 备份-所有数据库的表结构及数据
#方法一:所有表结构及数据
docker exec -it mysql5 mysqldump -uroot -proot --all-databases > \
~/data/backup_2022.sql

#方法二:所有表结构及数据
docker exec mysql5 sh -c 'exec mysqldump -uroot -proot --all-databases' > \
~/data/backup_2022.sql
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 还原-所有数据库的表结构及数据
#1.将数据从宿主机复制到docker 容器
docker cp ~/data/backup_2022.sql \
$(docker ps -a |grep mysql5 |awk '{print $1}'):/tmp
#2.进入宿主机,登陆mysql
docker exec -it mysql5 mysql -uroot -proot
#3.创建临时数据库
create database tempdb;
#4.切换数据库
use tempdb;
#5.还原数据库
source /tmp/backup_2022.sql
#6.还原数据库
drop database tempdb;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

3、单个数据库

  • 备份-单个数据库的表结构及数据
#1.将数据从数据库中备份到本地
docker exec -it mysql5 mysqldump -uroot -proot backupdb > \
~/data/backup_2022.sql
  • 1
  • 2
  • 3
  • 还原-单个数据库的表结构及数据
#1.将数据从宿主机复制到docker 容器
docker cp ~/data/backup_2022.sql \
$(docker ps -a |grep mysql5 |awk '{print $1}'):/tmp
#2.进入宿主机,登陆mysql
docker exec -it mysql5 mysql -uroot -proot
#3.创建临时数据库
create database backupdb;
#4.切换数据库
use backupdb;
#5.还原数据库
source /tmp/backup_2022.sql
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

4、只导数据不导结构

docker exec -it mysql5 mysqldump -t -uroot -proot backupdb > \
~/data/backup_2022.sql
  • 1
  • 2

5、只导结构不导数据

docker exec -it mysql5 mysqldump --opt -d -uroot -proot backupdb > \
~/data/backup_2022.sql
  • 1
  • 2

6、导出特定表的结构

docker exec -it mysql5 mysqldump --single-transaction -uroot -proot backupdb sys_user \
> ~/data/backup_2022.sql
  • 1
  • 2

注意:例4、例5、例6的还原方式可以参照例1;

所有文章均为本人原创,本人写作的目的就是想帮助对技术有需要的人,所以欢迎同行转载本站文章,但是希望您注明来源,并留下原文链接地址,这是对文章作者的尊重,也是对知识的尊重。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/IT小白/article/detail/933580
推荐阅读
相关标签
  

闽ICP备14008679号

        
cppcmd=keepalive&