【Docker】MySQL容器定时备份

当在Docker中的MySQL数据库执行mysqldump进行备份时,使用dockerexec命令需要注意参数。在命令行直接运行与在定时器中执行的区别在于是否需要-it选项。手动执行需要交互式终端,而定时任务已经在终端上下文中,因此应去掉-t,正确的命令是dockerexec-i$container_namemysqldump-uroot-p123456--databasesdb1db2>/data_backup/xxx.sql。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们通常使用原生的mysql会比较多,mysql的备份也耳熟能详。假如现在有个mysql数据库username为root,password为123456,且现在要导出schema为db1、db2的数据。
在本地导出的时候我们可以通过

mysqldump -uroot -p123456 --databases db1 db2 > /data_backup/xxx.sql

将schema为db1、db2的数据导出到路径为/data_backup/xxx.sql的文件中。
但是若mysql为docker镜像的时候应该怎样进行导出呢?
很多同学也许会想着使用

docker exec -it $container_name mysqldump -uroot -p123456 --databases db1 db2 > /data_backup/xxx.sql

进行导出。但是会发现直接使用上面语句导出是可以得到xxx.sql的数据备份的,但是如果将语句放在定时器上执行却是得到一个为空的xxx.sql文件。
究竟是为什么呢?
通常我们意识里会认为能够执行的语句或者脚本也可以通过定时器去执行,定时器只是做一个触发的动作而已。
是的,的确没有错,但是问题就在于如何触发执行里。
当我们手动执行的时候是通过docker exec -it去创建一个伪终端去执行mysqldump的,所以是可行的。
但是在定时器自动触发的时候本来就是在终端里面,因此是不需要通过-it进行伪终端的创建的,因为后者是没有宿主机的环境变量的,因此会报错。
所以正确的命令为:

docker exec -i $container_name mysqldump -uroot -p123456 --databases db1 db2 > /data_backup/xxx.sql

把t去掉就可以了。

docker mysql 定时备份脚本可以通过在Docker容器中运行CRON任务来实现。在提供的引用内容中,并没有直接包含docker mysql定时备份脚本的详细说明。但是,我们可以根据提供的资源包含了MySQL的配置文件和一些其他脚本文件,来组合实现定时备份脚本。 下面是一种可能的实现方法: 1. 首先,进入Docker容器中的MySQL配置文件目录,并修改my.cnf文件来启用MySQL的binlog。在binlog中记录的操作日志可以用于恢复数据库到指定的时间点。 2. 接下来,创建一个备份脚本文件,将其保存为backup.sh或者其他指定名称。该脚本文件将执行MySQL备份的操作。脚本内容大致如下: ``` #!/bin/bash # 设置备份目录 BACKUP_DIR=/path/to/backup # 设置备份文件名 BACKUP_FILE=mysql_backup_$(date +%Y%m%d%H%M%S).sql # 执行备份命令 mysqldump -u <username> -p<password> -h <host> --all-databases > $BACKUP_DIR/$BACKUP_FILE ``` 3. 接下来,创建一个定时任务脚本文件,将其保存为cron.sh或者其他指定名称。该脚本文件将设置定时任务,并执行备份脚本。脚本内容大致如下: ``` #!/bin/bash # 设置定时任务执行频率,例如每天凌晨3点执行备份 CRON_SCHEDULE="0 3 * * *" # 设置备份脚本文件路径 BACKUP_SCRIPT=/path/to/backup.sh # 添加定时任务 echo "$CRON_SCHEDULE root $BACKUP_SCRIPT" >> /etc/crontab # 重新加载cron服务 service cron reload ``` 4. 最后,通过在Docker容器中运行cron.sh脚本,即可设置定时任务并执行备份操作。 ``` $ sh cron.sh ``` 需要注意的是,以上脚本内容仅为示例,具体的配置和操作需要根据实际情况进行调整。 参考资料: 提供的资源包含的Spark集群配置文件
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Kida 的技术小屋

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值