12.Linux系统:定时任务执行恢复sql文件到数据库

1.创建脚本

mysql_restore.sh内容如下:

#!/bin/bash
#查找名称为“mysql_mysql”的容器id
CONTAINER_ID=`docker ps  -a | grep "mysql_mysql" | awk '{print $1}' | head -n 1`
MYSQL_USERNAME="root"
MYSQL_PASSWORD="root"
#文件名称为"my_db_prod当天日期.sql"
FILENAME1=my_db1_prod`date +%Y%m%d`.sql
FILENAME2=my_db2_prod`date +%Y%m%d`.sql

echo "开始恢复.sql到数据库"
#备份sql文件所在目录
data_dir="/usr/local/soft/mysql/deploy/backups/sql/"

docker exec -i $CONTAINER_ID  mysql -u$MYSQL_USERNAME -p$MYSQL_PASSWORD my_db1 < "$data_dir/$FILENAME1" 

docker exec -i $CONTAINER_ID  mysql -u$MYSQL_USERNAME -p$MYSQL_PASSWORD my_db2 < "$data_dir/$FILENAME2"
echo "结束备份.sql到数据库"
if [ $? -ne 0 ];then

# 任务失败,发送邮件

echo -e "执行数据库任务失败" | mail -s '执行数据库任务失败' 213454290@qq.com

exit -1

fi

#删除所有日期超过15天的备份文件
find $data_dir -mtime +15 -name '*.sql' -exec rm -rf {} \;


执行内容:

  • (1)将目录 /usr/local/soft/mysql/deploy/backups/sql/ 下“my_db1_prod当前日期.sql”文件执行到my_db1下;
    将目录 /usr/local/soft/mysql/deploy/backups/sql/ 下“my_db2_prod当前日期.sql”文件执行到my_db2下;
  • (2)删除所有日期超过15天的备份文件

2. crontab创建定时任务

2.1 进入编辑定时任务模式

crontab -e

2.2 输入定时任务命令

#每日凌晨1点执行rm_json_log_file.sh文件
0 1 * * * sh /usr/local/soft/rm_json_log_file.sh 
#每日凌晨2点执行mysql_dumps.sh文件,进行备份数据库
0 2 * * * sh /usr/local/deploy_epower/mysql_redis/mysql/backups/sh/mysql_dumps.sh

2.3 退出编辑模式

ESC #按ESC键退出编辑模式
:wq #键入:wq保存

2.4 重启crontab服务

service crontab restart

2.5 查看定时任务列表

crontab -l

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值