docker下mysql容器数据的定时备份与恢复
1、数据备份脚本
vim mysqldump.sh
#!/bin/bash
docker exec -i 容器id/容器名 mysqldump -uroot -proot -A > /mydata/mysqldump/mydb.sql
-A 表示备份所有数据库的结构和数据。更多内容请看:https://blog.csdn.net/qq_36264795/article/details/127665352
直接在docker里执行备份则使用:docker exec -it 容器id/容器名 mysqldump -uroot -proot -A > /mydata/mysqldump/mydb.sql
2、添加定时任务。cron表达式更多内容请看:https://www.51cto.com/article/681950.html
vim /etc/crontab
0 1 * * * root /home/script/mysqldump.sh
3、数据恢复
1)将备份文件copy到容器内:
## docker cp 源文件路径 容器id/容器名:容器内目标路
docker cp /mydata/mysqldump/mydb.sql mysql:/etc/mysql
2)进入容器连接mysql,使用source进行恢复:
docker exec -it mysql /bin/bash
mysql -uroot -proot
source /etc/mysql/mydb.sql
贵有恒,何必三更睡五更起最是无用。