欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2024-03-31 11:51:04
1.先创建一个数据库备份目录: mkdir backup cd backup mkdir mysqlbackup cd mysqlbackup...

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参数 忽略错误