萬盛學電腦網

 萬盛學電腦網 >> 數據庫 >> mysql教程 >> linxu中每天自動備份mysql兩段腳本

linxu中每天自動備份mysql兩段腳本

mysql自動備份要借助於linux中的crontab任務計劃,我們把.sh文件寫好之後需要加入到linux中crontab中,然後設置備份數據庫的執行時間,下面我來介紹介紹。

定時執行腳本:


執行

 代碼如下 復制代碼

crontab -e 00 00 * * * /bin/bash yourpath/mysqlbak.sh


打開自動執行文件

 

 代碼如下 復制代碼 vi /etc/crontab

在etc中加入如下內容,讓其自動執行任務。

 代碼如下 復制代碼

00 00 * * * root /mysqlbak.sh

以上兩個 00    00    *    *    *  為每天的凌晨自動執行腳本

分 時 日 月 周 命令

M: 分鐘(0-59)。每分鐘用*或者 */1表示
H:小時(0-23)。(0表示0點)
D:天(1-31)。
m: 月(1-12)。
d: 一星期內的天(0~6,0為星期天)。

每五分鐘執行    */5 * * * *
每小時執行      0 * * * *
每天執行        0 0 * * *
每周執行        0 0 * * 0
每月執行        0 0 1 * *
每年執行        0 0 1 1 *


重啟cron

 代碼如下 復制代碼

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

or

service crond restart


實例一

mysqlback.sh

 

 代碼如下 復制代碼 #!/bin/bash
#功能說明:本功能用於備份數據庫
#編寫日期:2010/12/06
 
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:/usr/local/mysql/bin
export PATH
#數據庫用戶名
dbuser='root'
#數據庫密碼
dbpasswd='123456'
#數據庫名,可以定義多個數據庫,中間以空格隔開,如:test test1 test2
dbname='test1 test2'
#備份時間
backtime=`date +%Y%m%d%H%M%S`
#日志備份路徑
logpath='/second/backup'
#數據備份路徑
datapath='/second/backup'
#日志記錄頭部
echo ‘"備份時間為${backtime},備份數據庫表 ${dbname} 開始" >> ${logpath}/mysqllog.log
#正式備份數據庫
for table in $dbname; do
source=`mysqldump -u ${dbuser} -p${dbpasswd} ${table}> ${logpath}/${backtime}.sql` 2>> ${logpath}/mysqllog.log;
#備份成功以下操作
if [ "$?" == 0 ];then
cd $datapath
#為節約硬盤空間,將數據庫壓縮
tar jcf ${table}${backtime}.tar.bz2 ${backtime}.sql > /dev/null
#刪除原始文件,只留壓縮後文件
rm -f ${datapath}/${backtime}.sql
echo "數據庫表 ${dbname} 備份成功!!" >> ${logpath}/mysqllog.log
else
#備份失敗則進行以下操作
echo "數據庫表 ${dbname} 備份失敗!!" >> ${logpath}/mysqllog.log
fi
done


實例2

每天凌晨執行一次,自動備份 這個腳本每天最多只執行一次,而且只保留最近五天的備份在服務器上。

 代碼如下 復制代碼

#!/bin/bash
#This is a ShellScript For Auto DB Backup
#Powered by aspbiz
#2004-09

#Setting
#設置數據庫名,數據庫登錄名,密碼,備份路徑,日志路徑,數據文件位置,
#以及備份方式
#默認情況下備份方式是tar,還可以是mysqldump,mysqldotcopy
#默認情況下,用root(空)登錄mysql數據庫,備份至/root/dbxxxxx.tgz
DBName=mysql
DBUser=root
DBPasswd=
BackupPath=/root/
LogFile=/root/db.log
DBPath=/var/lib/mysql/
#BackupMethod=mysqldump
#BackupMethod=mysqlhotcopy
#BackupMethod=tar
#Setting End


NewFile="$BackupPath"db$(date +%y%m%d).tgz
DumpFile="$BackupPath"db$(date +%y%m%d)
OldFile="$BackupPath"db$(date +%y%m%d --date='5 days ago').tgz

echo "-------------------------------------------" >> $LogFile
echo $(date +"%y-%m-%d %H:%M:%S") >> $LogFile
echo "--------------------------" >> $LogFile
#Delete Old File
if [ -f $OldFile ]
then
   rm -f $OldFile >> $LogFile 2>&1
   echo "[$OldFile]Delete Old File Success!" >> $LogFile
else
   echo "[$OldFile]No Old Backup File!" >> $LogFile
fi

if [ -f $NewFile ]
then
   echo "[$NewFile]The Backup File is exists,Can't Backup!" >> $LogFile
else
   case $BackupMethod in
   mysqldump)
      if [ -z $DBPasswd ]
      then
         mysqldump -u $DBUser --opt $DBName > $DumpFile
      else
         mysqldump -u $DBUser -p$DBPasswd --opt $DBName > $DumpFile
      fi
      tar czvf $NewFile $DumpFile >> $LogFile 2>&1
      echo "[$NewFile]Backup Success!" >> $LogFile
      rm -rf $DumpFile
      ;;
   mysqlhotcopy)
      rm -rf $DumpFile
      mkdir $DumpFile
      if [ -z $DBPasswd ]
      then
         mysqlhotcopy -u $DBUser $DBName $DumpFile >> $LogFile 2>&1
      else
         mysqlhotcopy -u $DBUser -p $DBPasswd $DBName $DumpFile >>$LogFile 2>&1
      fi
      tar czvf $NewFile $DumpFile >> $LogFile 2>&1
      echo "[$NewFile]Backup Success!" >> $LogFile
      rm -rf $DumpFile
      ;;
   *)
      /etc/init.d/mysqld stop >/dev/null 2>&1
      tar czvf $NewFile $DBPath$DBName >> $LogFile 2>&1
      /etc/init.d/mysqld start >/dev/null 2>&1
      echo "[$NewFile]Backup Success!" >> $LogFile
      ;;
   esac
fi

echo "-------------------------------------------" >> $LogFile 

copyright © 萬盛學電腦網 all rights reserved