如何定时备份mysql数据库

通过编写脚本 在linux中添加定时任务执行脚本

1、编写shell脚本

#!/bin/bash
#数据库IP
dbserver='127.0.0.1'
#数据库用户名
dbuser='root'
#数据密码
dbpasswd='123456'
#数据库,如有多个库用空格分开
dbname='study'
#备份时间
backtime=`date +%Y%m%d%H%M%S`
#备份输出日志路径
logpath='/opt/study/mysql/mysqlbak'


echo "################## ${backtime} #############################" 
echo "开始备份" 
#日志记录头部
echo "" >> ${logpath}/mysqlback.log
echo "-------------------------------------------------" >> ${logpath}/mysqlback.log
echo "备份时间为${backtime},备份数据库表 ${dbname} 开始" >> ${logpath}/mysqlback.log
#正式备份数据库
for table in $dbname; do
source=`mysqldump -h ${dbserver} -u ${dbuser} -p${dbpasswd} ${table} > ${logpath}/${backtime}.sql` 2>> ${logpath}/mysqlback.log;
#备份成功以下操作
if [ "$?" == 0 ];then
cd $logpath
#为节约硬盘空间,将数据库压缩
tar zcf ${table}${backtime}.tar.gz ${backtime}.sql > /dev/null
#删除原始文件,只留压缩后文件
rm -f ${datapath}/${backtime}.sql
#删除七天前备份,也就是只保存7天内的备份
find $logpath -name "*.tar.gz" -type f -mtime +7 -exec rm -rf {} \; > /dev/null 2>&1
echo "数据库表 ${dbname} 备份成功!!" >> ${logpath}/mysqlback.log
else
#备份失败则进行以下操作
echo "数据库表 ${dbname} 备份失败!!" >> ${logpath}/mysqlback.log
fi
done
echo "完成备份"
echo "################## ${backtime} #############################"

2、添加定时任务

crontab内容格式介绍

用户所建立的crontab文件中,每一行都代表一项任务,每行的每个字段代表一项设置,它的格式共分为六个字段,前五段是时间设定段,第六段是要执行的命令段,格式如下:

minute hour day month week command

其中:

​ 1、minute: 表示分钟,可以是从0到59之间的任何整数;

​ 2、hour:表示小时,可以是从0到23之间的任何整数;

​ 3、day:表示日期,可以是从1到31之间的任何整数;

​ 4、month:表示月份,可以是从1到12之间的任何整数;

​ 5、week:表示星期几,可以是从0到6之间的任何整数,这里的0代表星期日;

​ 6、command:要执行的命令,可以是系统命令,也可以是自己编写的脚本文件。

前五个时间设定段,可以含如下特殊字符:

​ 1、星号(*):代表所有可能的值,例如month字段如果是星号,则表示在满足其它字段的制约条件后每月都执行该命令操作;

​ 2、逗号(,):可以用逗号隔开的值指定一个列表范围,例如,“1,2,5,7,8,9”;

​ 3、中杠(-):可以用整数之间的中杠表示一个整数范围,例如“2-6”表示“2,3,4,5,6”;

​ 4、正斜线(/):可以用正斜线指定时间的间隔频率,例如“0-23/2”表示每两小时执行一次。同时正斜线可以和星号一起使用,例如*/10,如果用在minute字段,表示每十分钟执行一次。

crontab -l 查看定时任务列表
crontab -e 添加定时任务
crontab -r 删除定时任务,会删除所有的,如果想编辑定时任务,用crontab -e 进入编辑
*/1 * * * * sh /opt/zfc/mysqlbak.sh 每一分钟执行一次

3、定时任务执行失败查看

有时会发现脚本文件虽然执行,但是没有生效,数据备份失败,可以通过修改定时任务执行,将执行过程记录下来查看分析

*/1 * * * * sh /opt/zfc/mysqlbak.sh >> /opt/zfc/cron.log 2>&1

然后去查看cron.log文件,发现找不到mysqldump命令

cat   /opt/zfc/cron.log

################## 20200831113401 #############################
开始备份
/home/backup/mysqlbackup.sh: line 24: mysqldump: command not found
完成备份
################## 20200831113401 #############################
################## 20200831113402 #############################
开始备份
/home/backup/mysqlbackup.sh: line 24: mysqldump: command not found
完成备份
################## 20200831113402 #############################
################## 20200831113501 #############################
开始备份
/home/backup/mysqlbackup.sh: line 24: mysqldump: command not found
完成备份
################## 20200831113501 #############################

原因:这是由于系统默认会查找/usr/bin下的命令,如果这个命令不在这个目录下,就会报这种错误,我们需要做的就是映射一个链接到/usr/bin目录下,相当于建立一个链接文件。

首先得知道mysql命令或mysqldump命令的完整路径

find / -name mysql -print 查找mysql软件所在目录

/run/lock/subsys/mysql
/disk/mysql
/disk/mysql/mysqldata/mysql
/disk/mysql/product/bin/mysql
/disk/mysql/product/include/mysql
/etc/apparmor.d/abstractions/mysql

我的是在 /disk/mysql/product/bin/ 目录下,设置软链接

ln -fs  /disk/mysql/product/bin/mysqldump /usr/bin
ln -fs  /disk/mysql/product/bin/mysql  /usr/bin

设置之后,再去试试定时任务就可以了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值