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

你可能感兴趣的:(二,数据库,数据库,linux,sql)