当前位置: 移动技术网 > IT编程>数据库>Mysql > 讲解Linux系统下如何自动备份MySQL数据的基本教程

讲解Linux系统下如何自动备份MySQL数据的基本教程

2017年12月12日  | 移动技术网IT编程  | 我要评论

1.先创建一个数据库备份目录:

mkdir backup
cd backup
mkdir mysqlbackup
cd mysqlbackup

2.创建备份脚本

vi mysqlautobackup

3.编写脚本:

filename=`date +%y%m%d`
/mysql的bin目录/mysqldump --opt 数据库名 -u(mysql账号) -p(mysql密码) | gzip > /备份到哪个目录/name$filename.gz


说明:以上采用gzip压缩,name可随意写,注意-u与mysql账号之间没有空格也无需括号,-p与mysql密码也是。
4.将脚本设置为可执行权限:

chmod +x autobackup


5.写入计划任务:

crontab -e
01 01 * * * /bin/bash /脚本所在目录/mysqlautobackup


每天凌晨1点零1分执行脚本。
重启计划任务:

/etc/rc.d/init.d/crond restart


至此所有步骤完成。

一些常用技巧
1、创建保存备份文件的路径/mysqldata

#mkdir /mysqldata

2、创建/usr/sbin/baktest文件
输入以下内容:

mysqldump -uroot -proot test | gzip > /mysqldata/test`date +%y-%m-%d_%h%m%s`.sql.gz

3、修改文件属性,使其可以执行

#chmod +x /usr/sbin/baktest

4、修改/etc/crontab
在下面添加

01 3 * * * root /usr/sbin/baktest

表示每天3点钟01分执行备份

5、重新启动crond

#/etc/rc.d/init.d/crond restart

完成。


ps:
全备份脚本:

#!/bin/bash
# name:qbk全备份脚本
# mysql qbk scripts
# by zxsdw.com
# last modify:2015-01-21
#定义脚本存放路径
#scriptsdir=/usr/sbin
#定义用户名及密码
user=root
userpwd=密码
#定义要备份的数据库
database=数据库
#定义完全备份文件存放路径
bakdir=/backup/mysql
#emailfile=$bakdir/email.txt
#email=admin@zxsdw.com
#定义日志文件
logfile=$bakdir/mysqlbak.log
date=`date +%y%m%d`
echo " " >> $logfile
echo " " >> $logfile
echo "--------------------------" >> $logfile
echo $(date +"%y-%m-%d %h:%m:%s") >>$logfile
echo "-----------------" >> $logfile
cd $bakdir
dumpfile=$date.sql.gz
mysqldump --flush-logs -u$user -p$userpwd --quick $database| gzip >$dumpfile
echo "dump done" >> $logfile
echo "[$dumpfile]backup success!" >> $logfile
daily_databakdir=$bakdir/daily_backup
cd $bakdir/daily_backup
find $daily_databakdir -name "daily*" -type f -mtime +35 -exec rm {} \; > /dev/null 2>&1


增量备份脚本

#!/bin/bash
# name:zbk增量备份
# mysql zbk scripts
# by zxsdw.com
# last modify:2015-01-21


#定义数据库用户名及密码
user=root
userpwd=密码
#定义数据库
database=数据库
#生成一个新的mysql-bin.00000x文件,如果err日志被清除,则自动新建一个。
/usr/local/mysql/bin/mysqladmin -u$user -p$userpwd flush-logs
#定义增量备份位置
daily_databakdir=/backup/mysql/daily_backup
#定义mysql数据日志目录
mysqldatadir=/usr/local/mysql/var
#定义增量日志及目录
emailfile=$daily_databakdir/email.txt
#email=admin@zxsdw.com
#定义变量date格式为20150127
date=`date +%y%m%d`
#定义一个总的logfile日志
logfile=$daily_databakdir/mysql$date.log


#美化日志模板
echo "    " > $emailfile
echo "-----------------------" >> $emailfile
#时间格式为15-01-27 01:06:17
echo $(date +"%y-%m-%d %h:%m:%s") >> $emailfile
echo "-------------------------" >> $emailfile


#定义删除bin日志的时间范围,格式为20150124010540
time=$(date "-d 3 day ago" +%y%m%d%h%m%s)
#定义需要增量备份数据的时间范围,格式为2015-01-26 01:04:11
starttime=$(date "-d 1 day ago" +"%y-%m-%d %h:%m:%s")

###########开始删除操作美化日志标题##############
echo "delete 3 days before the log" >>$emailfile

#删除三天前的bin文件,及更新index里的索引记录,美化日志标题
mysql -u$user -p$userpwd -e "purge master logs before ${time}" && echo "delete 3 days before log" |tee -a $emailfile

#查找index索引里的bin 2进制文件并赋值给 i。
filename=`cat $mysqldatadir/mysql-bin.index |awk -f "/" '{print $2}'`
for i in $filename
do
#########开始增量备份操作,美化日志标题###########
echo "$starttime start backup binlog" >> $emailfile

#利用mysqlbinlog备份1天前增加的数据,并gzip压缩打包到增量备份目录
/usr/local/mysql/bin/mysqlbinlog -u$user -p$userpwd -d $database --start-datetime="$starttime" $mysqldatadir/$i |gzip >> $daily_databakdir/daily$date.sql.gz |tee -a $emailfile

done


#如果以上备份脚本执行成功,接着运行下面的删除脚本
if [ $? = 0 ]
then
# 删除mtime>32的增量日志备份文件
find $daily_databakdir -name "*.log" -type f -mtime +32 -exec rm {} \; > /dev/null 2>&1
cd $daily_databakdir
echo "daily backup succeed" >> $emailfile
else
echo "daily backup fail" >> $emailfile
#mail -s "mysql backup" $email < $emailfile #备份失败之后发送邮件通知
#fi结束if判断
fi


#把变量emailfile的内容替换logfile内容
cat $emailfile > $logfile

#如果上面的if判断失败,再次运行删除mtime>32的增量日志备份文件
find $daily_databakdir -name "*.log" -type f -mtime +32 -exec rm {} \; > /dev/null 2>&1
rsync -vzrtopg --delete --progress --password-file=/usr/local/rsync/rsync.passwd root@$ip:/zxs/allimg/$(date -d -1day +%y%m%d) /zxs/allimg/
gunzip < /backup/mysql/daily_backup/ceshi.sql.gz | /usr/local/mysql/bin/mysql -u用户名 -p密码 数据库名 --force
--force参数 忽略错误

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网