docker中mysql数据定时备份_docker下mysql定时任务备份及遇到问题

备份mysql

注:部分为网上找到,后面加以修改。

创建脚本

命令:vi mysql_backup.sh

内容如下:

#!/bin/bash

# 设置mysql的登录用户名和密码(根据实际情况填写)

mysql_user="root"

mysql_password="123456"

mysql_host="localhost"

mysql_port="3306"

mysql_charset="utf8mb4"

# 备份文件存放地址(根据实际情况填写)

backup_location=/usr/local

# 是否删除过期数据

expire_backup_delete="ON"

expire_days=7

backup_time=`date +%Y%m%d%H%M`

backup_dir=$backup_location

welcome_msg="Welcome to use MySQL backup tools!"

# 备份指定数据库中数据(此处我要备份的数据库为longxing)

docker exec -i mymysql mysqldump -h$mysql_host -P$mysql_port -u$mysql_user -p$mysql_password -B longxing > $backup_dir/$backup_time.sql

# 删除过期数据

if [ "$expire_backup_delete" == "ON" -a "$backup_location" != "" ];then

`find $backup_location/ -type f -mtime +$expire_days | xargs rm -rf`

echo "Expired backup data delete complete!"

fi

**注 在上面执行命令时一定不能为docker exec -it 不然执行任务时会出现:the input device is not a TTY错误 **

执行以下命令:

chmod u+x *.sh

创建定时任务

命令: crontab -e

在编辑框输入:

09 11 * * * cd /home/dbback;sh mysql_backup.sh >> log.txt 2>>log.txt

这边做下注释:前面时间表示任务启动时间为11点09分。脚本位置为:/home/dbback目录下。后面就不用说了。

最终执行结果:

7f919d0493e2a084edf525b2018afbed.png

本文由博客群发一文多发等运营工具平台 OpenWrite 发布

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值