mysql docker远程备份数据库_Docker安装的mysql使用mysqldump定时备份数据库

1、crontab 是用来让使用者在固定时间或固定间隔执行程序之用

手动启动crontab服务:

service crond start

2、mysqldump

docker中mysqldump的完整路径docker exec /usr/bin/mysqldump。

3、数据库备份脚本

功能:mysql 每天定时备份, 并删除7天以前的备份

mysql_dumps.sh:

#!/bin/bash

docker_name = mysql57

data_dir="/path/to/save/data/"

docker exec-it ${docker_name} mysqldump -uroot -ppasswd --all-databases > "$data_dir/data_`date +%Y%m%d`.sql"

if [ $? -ne 0 ];then

# 任务失败,发送邮件

echo -e "邮件正文" | mail -s '标题' 123456@gmail.com

exit -1

fi

find $data_dir -mtime +7 -name 'data_[1-9].sql' -exec rm -rf {} \;

4、通过linux cron设置定时任务

crontab -e:

0 2 * * * sh /absolute/path/to/mysql_dumps.sh > /absolute/path/to/mysql_dumps.log 2>&1

5、遇到的问题

/bin/sh^M: bad interpreter: No such file or directory

原因:这是不同系统编码格式引起的:在windows系统中编辑的.sh文件可能有不可见字符,所以在Linux系统下执行会报以上异常信息。

解决:

1).在windows下转换:

利用一些编辑器如UltraEdit或EditPlus等工具先将脚本编码转换,再放到Linux中执行。转换方式如下(UltraEdit):File-->Conversions-->DOS->UNIX即可。

2).在linux中编写改脚本。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值