在Docker中备份MySQL数据库,可以采用以下两种方法:
使用 mysqldump
工具备份
-
首先,进入MySQL容器。如果使用
docker-compose
,可以通过以下命令进入:docker-compose exec mysql bash
如果使用单个容器,可以使用以下命令:
docker exec -it mysql bash
-
在容器内,使用
mysqldump
命令备份数据库。假设要备份的数据库名为mydb
,备份文件保存到宿主机的backup
目录下,可以使用以下命令:mysqldump -u root -p mydb > /path/to/backup/mydb_backup.sql
其中,
-u root -p
是登录MySQL的用户名和密码,/path/to/backup/
是备份文件在宿主机上的保存路径。执行此命令后,系统会提示输入密码,然后开始备份。
使用 Docker 卷(推荐)
-
创建一个用于备份的Docker卷:
docker volume create mysql_backup
-
停止并删除MySQL容器(如果需要保留数据,请确保已设置MySQL的数据卷):
docker-compose down
或者,对于单个容器:
docker stop mysql docker rm mysql
-
使用新的数据卷重新启动MySQL容器:
docker-compose up -d --name mysql -v mysql_backup:/var/lib/mysql mysql
对于单个容器:
docker run -d --name mysql -v mysql_backup:/var/lib/mysql mysql
-
在MySQL容器内,创建一个用于备份的目录,并将备份文件保存到这个目录中。可以使用以下命令:
mkdir /backup mysqldump -u root -p mydb > /backup/mydb_backup.sql
其中,
/backup/
是备份文件在MySQL容器内的保存路径。执行此命令后,系统会提示输入密码,然后开始备份。
通过以上任一方法,你都可以成功地在Docker中备份MySQL数据库。