Linux服務器備份:VPS備份腳本_Linux教程

      編輯Tag賺U幣

      Linux服務器備份:VPS服務器網站及數據庫自動本地備份并上傳到FTP服務器

      從VPS偵探建站之初就一直在重申一定要備份好自己的數據,因為太多的不確定性可能會造成數據庫丟失,而且大部分VPS服務商也不可能提供每天備份數據。

      原來VPS偵探提供過一個VPS備份方法,只是略微說了一下,可能部分新手會不太好入手。今天VPS偵探分享一個自己的備份腳本。

      準備工作:

      需要提前在VPS安裝好lftp,lftp功能上比較強大,CentOS直接執行:yum install lftp,Debian執行:apt-get install lftp

      需要在VPS上創建/home/backup/ 目錄,在FTP上創建backup目錄。

      如果VPS上數據庫不多的話使用Godaddy的免費空間就可以(10GB空間,300GB流量),只要注冊個域名就免費送。

      下面將備份腳本進行部分注釋:

       

      #!/bin/bash
      #Funciont: Backup website and mysql database
      #Author: licess
      #Website: http://lnmp.org
      #IMPORTANT!!!Please Setting the following Values!

      ######~Set Directory you want to backup~######將下面的目錄修改成自己要備份的目錄,一般按我的都是在/home/wwwroot/下面所有直接寫了需要備份的目錄。可以繼續再加:Backup_Dir5=你的目錄 ,Backup_Dir后面的數字依次遞增。如果不足4個,直接刪除不需要的就可以,同時修改下面tar zcf 部分。

      Backup_Dir1=vpser.net
      Backup_Dir2=lnmp.org
      Backup_Dir3=licess.org
      Backup_Dir4=jungehost.com

      ######~Set MySQL UserName and password~######設置MySQL的用戶名和密碼,最好是root,其他用戶可能因為權限問題無法導出部分數據庫。
      MYSQL_UserName=root
      MYSQL_PassWord=yourmysqlrootpassword

      ######~Set MySQL Database you want to backup~######設置要部分的數據庫,可以繼續再加:Backup_Database_Name5=數據庫名,Backup_Database_Name后面的數字依次遞增。
      Backup_Database_Name1=vpser
      Backup_Database_Name2=licess
      Backup_Database_Name3=junge
      Backup_Database_Name4=vpserorg

      ######~Set FTP Information~######設置用來存放備份數據的FTP信息
      FTP_HostName=184.168.192.43   //FTP服務器的IP或者域名
      FTP_UserName=vpsernet                //FTP服務器用戶名
      FTP_PassWord=yourftppassword   //FTP服務器用戶對應的密碼
      FTP_BackupDir=backup                    //備份到FTP上的目錄,需要提前創建好。

      #Values Setting END!

      TodayWWWBackup=www-*-$(date +"%Y%m%d").tar.gz
      TodayDBBackup=db-*-$(date +"%Y%m%d").sql
      OldWWWBackup=www-*-$(date -d -3day +"%Y%m%d").tar.gz
      OldDBBackup=db-*-$(date -d -3day +"%Y%m%d").sql

      tar zcf /home/backup/www-$Backup_Dir1-$(date +"%Y%m%d").tar.gz -C /home/wwwroot/ $Backup_Dir1 --exclude=soft
      tar zcf /home/backup/www-$Backup_Dir2-$(date +"%Y%m%d").tar.gz -C /home/wwwroot/ $Backup_Dir2
      tar zcf /home/backup/www-$Backup_Dir3-$(date +"%Y%m%d").tar.gz -C /home/wwwroot/ $Backup_Dir3 --exclude=test
      tar zcf /home/backup/www-$Backup_Dir4-$(date +"%Y%m%d").tar.gz -C /home/wwwroot/ $Backup_Dir4

      ###上面為備份網站文件數據,因為我的網站比較零散,而且網站目錄下面有些目錄屬于臨時目錄并不需要備份,所以可以在上面加上--exclude=不備份的目錄。如果在前面加了Backup_Dir5=yourdir,則再加tar zcf /home/backup/www-$Backup_Dir5-$(date +"%Y%m%d").tar.gz -C
      /home/wwwroot/ $Backup_Dir5 。如果多余則刪除多余行。

      /usr/local/mysql/bin/mysqldump -u$MYSQL_UserName -p$MYSQL_PassWord $Backup_Database_Name1 > /home/backup/db-$Backup_Database_Name1-$(date +"%Y%m%d").sql
      /usr/local/mysql/bin/mysqldump -u$MYSQL_UserName -p$MYSQL_PassWord $Backup_Database_Name2 > /home/backup/db-$Backup_Database_Name2-$(date +"%Y%m%d").sql
      /usr/local/mysql/bin/mysqldump -u$MYSQL_UserName -p$MYSQL_PassWord $Backup_Database_Name3 > /home/backup/db-$Backup_Database_Name3-$(date +"%Y%m%d").sql
      /usr/local/mysql/bin/mysqldump -u$MYSQL_UserName -p$MYSQL_PassWord $Backup_Database_Name4 > /home/backup/db-$Backup_Database_Name4-$(date +"%Y%m%d").sql

      ###上面為備份MySQL數據庫,如果在前面加了Backup_Database_Name5=yourdatabasename,則再加/usr/local/mysql/bin/mysqldump -u$MYSQL_UserName -p$MYSQL_PassWord $Backup_Database_Name5 > /home/backup/db-$Backup_Database_Name5-$(date +"%Y%m%d").sql 。如果多余則刪除多余行。

      rm $OldWWWBackup
      rm $OldDBBackup
      ###刪除3天前的備份###

      cd /home/backup/

      ###下面為自動上傳部分,不得不說lftp很強大,拋棄ftp吧####
      lftp $FTP_HostName -u $FTP_UserName,$FTP_PassWord << EOF
      cd $FTP_BackupDir
      mrm $OldWWWBackup
      mrm $OldDBBackup
      mput $TodayWWWBackup
      mput $TodayDBBackup
      bye
      EOF

       

      腳本下載地址:http://soft.vpser.net/lnmp/backup.sh

      下載腳本,將腳本放到/root/ 下面,按上面的注釋修改腳本中的參數,并保存,如果不熟悉vi或者nano編輯器,可以用winscp,執行:crontab -e

      在crontab中加入:0 3 * * * /root/backup.sh

      凌晨3點自動執行/root/bakcup.sh 腳本,備份vps上的數據并上傳到FTP上。

      來源:網絡搜集//所屬分類:Linux教程/更新時間:2013-04-13
      相關Linux教程