MySQL镜像配置中的定期备份策略,主要依赖于容器化环境下的脚本调度与数据持久化机制。在使用Docker部署MySQL时,官方镜像本身不包含自动备份功能,需通过外部脚本结合
cron任务或第三方工具实现周期性备份。
1. 数据卷挂载确保数据可访问
为支持备份操作,必须将MySQL的数据目录挂载到宿主机或使用命名卷,以便备份脚本能读取数据文件或执行导出命令。
运行MySQL容器时,使用-v参数挂载数据卷:
示例命令:
docker run -d --name mysql-container \
-e MYSQL_ROOT_PASSWORD=your_password \
-v /host/mysql/data:/var/lib/mysql \
-v /host/mysql/backup:/backup \
mysql:8.0
其中
/backup目录用于存放导出的SQL文件。
2. 编写备份脚本(mysqldump方式)
创建一个Shell脚本,使用
mysqldump对数据库进行逻辑备份。 编写
backup.sh脚本:
#!/bin/bash
BACKUP_DIR="/backup"
MYSQL_USER="root"
MYSQL_PASS="your_password"
DATE=$(date +%Y%m%d_%H%M%S)
mysqldump -u$MYSQL_USER -p$MYSQL_PASS --single-transaction --routines --triggers --all-databases | gzip > "$BACKUP_DIR/all_databases_$DATE.sql.gz"
find $BACKUP_DIR -name "all_databases_*.sql.gz" -mtime +7 -delete
该脚本压缩备份并保留最近7天的数据。
3. 配置定时任务(cron)
在宿主机或独立的备份容器中设置
crontab,定期执行备份脚本。 编辑crontab:
crontab -e添加每日凌晨2点执行备份:
0 2 * * * /path/to/backup.sh
确保脚本有执行权限:
chmod +x backup.sh
4. 使用专用备份容器(推荐方案)
更规范的做法是创建一个独立的备份容器,连接到MySQL容器网络,按计划执行备份。
使用docker-compose.yml统一管理:
定义MySQL服务和备份服务,通过
depends_on和共享卷协调执行顺序,并借助
schedule类工具(如
wooden-spoon)或宿主机cron触发。
基本上就这些。关键是保证数据可访问、脚本能执行、周期可控制。根据实际需求调整备份频率和保留策略即可。
