搭建博客也有一年多的时间了,之前也没考虑过数据库备份的事情,就是要备份也是在云虚拟主机上手动备份。不过现在有云主机了,考虑一下自动备份也未尝不可,参照了网上的教程,并在此基础上是加入了将文件自动提交到git上的需求

原文:http://www.jb51.net/article/34376.htm

在linux中如果想定时备份数据库的脚本我们可以很方便简单的操作,下面我来分享一段mysql定时备份的脚本代码

第一步:在你的linux服务器中定义备份目录:

复制代码代码如下:

mkdir /var/lib/mysqlbackup 
cd /var/lib/mysqlbackup

第二步:下面是最重要的一步了,就是写定时备份脚本。

复制代码代码如下:

vi dbbackup.sh

复制代码代码如下:

#!/bin/sh
# mysql data backup script
BackDir=/usr/share/nginx/mysqlbackup
LogFile=/usr/share/nginx/mysqlbackup/mysqlbackup.log
DATE=`date +%Y%m%d%H%M%S`
echo " " >> $LogFile
echo " " >> $LogFile
echo "-------------------------------------------" >> $LogFile
echo $(date +"%y-%m-%d %H:%M:%S") >> $LogFile
echo "--------------------------" >> $LogFile
cd $BackDir
DumpFile=$DATE.sql
GZDumpFile=$DATE.sql.tar.gz
mysql -u root -p0772981057lbj  --database -h 127.0.0.1 blog> $DumpFile
echo "Dump Done" >> $LogFile
tar czvf $GZDumpFile $DumpFile >> $LogFile 2>&1
echo "[$GZDumpFile]Backup Success!" >> $LogFile
rm -f $DumpFile
#cd $BackDir/daily
cd $BackDir
git add .
git commit -m "备份日期:`date '+%Y%m%d %T'`"
git push origin master
echo "Backup Done!"
echo "please Check $BackDir Directory!"
echo "copy it to your local disk or ftp to somewhere !!!"

友情提示:其中user,name和db请根据自己的情况修改

保存退出,然后把这个文件赋予可执行的权限:

复制代码代码如下:

#chmod 777 mysqlautobackup.sh

用crontab定时执行备份脚本代码:

crontab -e

若每天下午3点20备份,添加如下代码,

复制代码代码如下:

20 15 * * * /var/lib/mysqlbackup/dbbackup.sh

这样就搞定了,每天会定时帮你备份mysql数据库了。