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