docker容器内mysql定时任务备份及遇到问题

   日期:2020-10-16     浏览:108    评论:0    
核心提示:备份mysql注:部分为网上找到,后面加以修改。创建脚本命令:vi mysql_backup.sh内容如下:#!/bin/bash# 设置mysql的登录用户名和密码(根据实际情况填写)mysql_user="root"mysql_password="123456"mysql_host="localhost"mysql_port="3306"mysql_charset="utf8mb4"

备份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目录下。后面就不用说了。

最终执行结果:

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

 
打赏
 本文转载自:网络 
所有权利归属于原作者,如文章来源标示错误或侵犯了您的权利请联系微信13520258486
更多>最近资讯中心
更多>最新资讯中心
0相关评论

推荐图文
推荐资讯中心
点击排行
最新信息
新手指南
采购商服务
供应商服务
交易安全
关注我们
手机网站:
新浪微博:
微信关注:

13520258486

周一至周五 9:00-18:00
(其他时间联系在线客服)

24小时在线客服