English |
  • 美国VPS主机推荐
  • |
  • 代购服务
  • |
  • 10美元以下VPS
  • |
  • VPS新手指南/教程
  • |
  • 留言板
  • |
  • 关于
  • | 登录 |

    Linux VPS/服务器 网站及数据库自动本地备份并FTP上传备份脚本

    2010年12月28日 上午 | 作者:VPS侦探

    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: https://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,执行:chmod +x /root/backup.sh 为脚本添加执行权限,执行:crontab -e 添加定时执行

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

    凌晨3点自动执行/root/bakcup.sh 脚本,备份vps上的数据并上传到FTP上。

    如果在使用过程中有任何问题请直接留言,或到VPS论坛发贴。原创文章,禁止转载!

    >>转载请注明出处:VPS侦探 本文链接地址:https://www.vpser.net/security/linux-autobackup-ftp.html
    VPS侦探推荐:
    遨游主机VultrLinode搬瓦工LOCVPSKVMLAHOSTKVMHostXen80VPS美国VPS主机,国内推荐腾讯云阿里云

    发表评论

    *必填

    *必填 (不会被公开)

    评论(67条评论)

    1. VPSer说道:

      @啊啊, 可能没给backup.sh加执行权限或crontab设置有问题

    2. 啊啊说道:

      不自动备份 都按上面操作的啊 自己执行sh backup.sh 会备份的。。 为嘛。。

    3. VPSer说道:

      @应用之家, Win的不了解

    4. 应用之家说道:

      学习了。。想知道WIN2003怎么自动备份啊。

    5. VPSer说道:

      @LOVER, 你看一下脚本里这个地方

    6. LOVER说道:

      我就奇怪,那个里面多了一个cd: /home/backup
      命令不是cd /home/backup 吗,多了冒号

    7. LOVER说道:

      问题是我已经通过FTP创建了,我是lnmp1.0的,难道用不了么

    8. VPSer说道:

      @lover, 目录没创建,mkdir /home/backup创建

    9. lover说道:

      没有那个文件或目录e 20: cd: /home/backup
      每次都是这样,怎么会这样呢?求救

    10. VPSer说道:

      @乐乐高, ftp上备份目录的权限设置有问题,可能不能写

    11. 乐乐高说道:

      军哥,你这个可以备份到/home/backup/里面有文件,但是没有上传到里面写的ftp那边。提示错误是:
      [root@MyVPS ~]# sh backup.sh
      tar: backup: Cannot stat: No such file or directory
      tar: Error exit delayed from previous errors
      Usage: rm [-r] [-f] files...
      Usage: rm [-r] [-f] files...
      mput: Access failed: 550 www-backup-20130114.tar.gz: Permission denied
      mput: Access failed: 550 db-overbestmall-20130114.sql: Permission denied

      这个backup路径是不是我在放备份文件那边的ftp自己新建的呢?
      还有那个数据库上传是不是权限不够,无法传到里面填写的ftp所对应的文件夹里面呢?

    12. 秋天一棵树说道:

      我用这个脚本备份到Godaddy的免费空间,但好像每次备份多不完整,Godaddy上的备份文件比VPS上的备份文件要小,手动执行备份则没有这个问题,是什么原因呢。

    13. 江南说道:

      学习了,可是备份的数据库如何恢复啊?

    14. VPSer说道:

      @fei, 按系统时间,一般安装了lnmp时间都是北京时间。

    15. fei说道:

      想问下,那个时间,是以哪个为准的,Linux时间吗?我想用北京时间,怎么弄?