讲解Linux系统下如何自动备份MySQL数据的基本教程
程序员文章站
2024-02-26 16:58:16
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参数 忽略错误