docker定时备份mysql数据库

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_32684319/article/details/86996369
1,写sh脚本,放在宿主机上的/shell下。
shell备份脚本如下:

 

# 保留10天数据,
# mysqldocker 为安装mysql的docker
docker exec -i mysqldocker bash<<'EOF'
# 判断目录是不是已经存在,如果不存在则创建
if [ ! -d "/backups/mysql" ]; then
  mkdir -p /backups/mysql
fi
# backups 为数据库的名称
mysqldump backups > /backups/mysql/backups_$(date +%Y%m%d).sql
#删除超过10天的数据
rm -f /backups/mysql/backups_$(date -d -10day +%Y%m%d).sql
exit
EOF
# 判断目录是不是已经存在,如果不存在则创建
if [ ! -d "/backups/mysql" ]; then
  mkdir -p /backups/mysql
fi
# 将docker中的备份的数据拷贝到宿主机上。
docker cp mysqldocker :/backups/mysql/backups_$(date +%Y%m%d).sql /backups/mysql
#删除超过10天的数据
rm -f /backups/mysql/backups_$(date -d -10day +%Y%m%d).sql

2,安装crontab
yum -y install vixie-cron
yum -y install crontabs
3,增加定时任务
crontab -e
1 0 * * * sh /shell/backups.sh 每天凌晨12点01分执行

如果执行.sh脚本出现
bash: line 1: $’\r’: command not found
错误,是因为转码的问题,解决方法
1,yum install dos2unix -y
2,dos2unix 文件名.sh


————————————————
版权声明:本文为CSDN博主「喻喻喻」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_32684319/article/details/86996369

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值