Docker Mysql 8 自动定时备份

Docker Mysql 8 自动定时备份

自服务器重新维护以后,上一次的 MySQL 数据库定时备份由于直接写在 crontab 中,导致这次再次测试却一直也不好使,反而导致我测试浪费了好几天。

这回从网上找到了其他方法,我今天测试了一下已经能够正常自动定时备份了。

创建备份文件

mkdir /data/backup
cd /data/backup

编写备份脚本代码

vim backup.sh
#!/bin/sh  #-h 后面改为自己的ip
#-u 后面改为自己的数据库账号
#-p 后面改为自己的数据库密码,有字符需要加""
#demand_database改为你想要备份的数据库名称
echo "开始备份数据库";
# 导出所有数据库 username 替换为自己mysql登陆名,password123登陆密码**
## mysqldump -h106.14.XX.XXX -uusername -p"password123" --all-databases > /data/mysqlbackup/databaseName`date +%Y-%m-%d_%H%M%S`.sql;

# 导出指定数据库并压缩
## mysqldump -h106.14.XX.XXX -uusername -p"password123"  demand_database| gzip > /data/mysqlbackup/databaseName`date +%Y-%m-%d_%H%M%S`.sql.gz;

# 最近转投docker怀抱,本地不安装mysql时,采用docker的mysql备份,备份语句修改为**
docker exec mysql sh -c 'exec mysqldump --all-databases -uUSERNAME -pPASSWORD --all-databases' > /data/backup/database_`date +%Y-%m-%d_%H%M%S`.sql;

# mysql 替换为对应的容器名
# 删除 3 天前的备份文件

backupdir=/data/backup
db_name=databaseName_

find $backupdir -name $db_name"*.sql.gz" -type f -mtime +3 -exec rm -rf {} \;


echo "备份完成";

测试以上代码需要根据自己的需求进行相应修改。

更改备份脚本权限

chmod +x dbbackup.sh

使用 crontab 定时执行备份脚本

crontab -e

输入上面的命令后会进入 vim 编辑的一个文件,在上面写 cron 表达式 + 脚本地址就行了

测试 每 1 分钟执行一次:

*/1 * * * *  /data/backup/backup.sh

我设定每 12 个小时更新一次,添加如下代码:

0 0 */12 * * /data/backup/backup.sh

参照文章

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值