Linux定时把数据库和网站打包备份到FTP上

  • A+
所属分类:杂谈

准备工作:

需要提前在VPS安装好lftp,lftp功能上比较强大。

CentOS直接执行:

  1. yum install lftp

Debian执行:

  1. apt-get install lftp

然后在VPS上创建/home/backup/ 目录,在FTP上创建backup目录。

  1. 下面将备份脚本进行部分注释:
  2. #!/bin/bash
  3. #Funciont: Backup website and mysql database
  4. #Author: licess
  5. #Website: http://lnmp.org
  6. #IMPORTANT!!!Please Setting the following Values!
  7. ######~Set Directory you want to backup~######将下面的目录修改成自己要备份的目录,一般按我的都是在/home/wwwroot/下面所有直接写了需要备份的目录。可以继续再加:Backup_Dir5=你的目录 ,Backup_Dir后面的数字依次递增。如果不足4个,直接删除不需要的就可以,同时修改下面tar zcf 部分。
  8. Backup_Dir1=vpser.net
  9. Backup_Dir2=lnmp.org
  10. Backup_Dir3=licess.org
  11. Backup_Dir4=jungehost.com
  12. ######~Set MySQL UserName and password~######设置MySQL的用户名和密码,最好是root,其他用户可能因为权限问题无法导出部分数据库。
  13. MYSQL_UserName=root
  14. MYSQL_PassWord=yourmysqlrootpassword
  15. ######~Set MySQL Database you want to backup~######设置要部分的数据库,可以继续再加:Backup_Database_Name5=数据库名,Backup_Database_Name后面的数字依次递增。
  16. Backup_Database_Name1=vpser
  17. Backup_Database_Name2=licess
  18. Backup_Database_Name3=junge
  19. Backup_Database_Name4=vpserorg
  20. ######~Set FTP Information~######设置用来存放备份数据的FTP信息
  21. FTP_HostName=184.168.192.43   //FTP服务器的IP或者域名
  22. FTP_UserName=vpsernet                //FTP服务器用户名
  23. FTP_PassWord=yourftppassword   //FTP服务器用户对应的密码
  24. FTP_BackupDir=backup                    //备份到FTP上的目录,需要提前创建好。
  25. #Values Setting END!
  26. TodayWWWBackup=www-*-$(date +"%Y%m%d").tar.gz
  27. TodayDBBackup=db-*-$(date +"%Y%m%d").sql
  28. OldWWWBackup=www-*-$(date -d -3day +"%Y%m%d").tar.gz
  29. OldDBBackup=db-*-$(date -d -3day +"%Y%m%d").sql
  30. tar zcf /home/backup/www-$Backup_Dir1-$(date +"%Y%m%d").tar.gz -C /home/wwwroot/ $Backup_Dir1 --exclude=soft
  31. tar zcf /home/backup/www-$Backup_Dir2-$(date +"%Y%m%d").tar.gz -C /home/wwwroot/ $Backup_Dir2
  32. tar zcf /home/backup/www-$Backup_Dir3-$(date +"%Y%m%d").tar.gz -C /home/wwwroot/ $Backup_Dir3 --exclude=test
  33. tar zcf /home/backup/www-$Backup_Dir4-$(date +"%Y%m%d").tar.gz -C /home/wwwroot/ $Backup_Dir4
  34. ###上面为备份网站文件数据,因为我的网站比较零散,而且网站目录下面有些目录属于临时目录并不需要备份,所以可以在上面加上--exclude=不备份的目录。如果在前面加了Backup_Dir5=yourdir,则再加tar zcf /home/backup/www-$Backup_Dir5-$(date +"%Y%m%d").tar.gz -C
  35. /home/wwwroot/ $Backup_Dir5 。如果多余则删除多余行。
  36. /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
  37. /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
  38. /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
  39. /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
  40. ###上面为备份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 。如果多余则删除多余行。
  41. rm $OldWWWBackup
  42. rm $OldDBBackup
  43. ###删除3天前的备份###
  44. cd /home/backup/
  45. ###下面为自动上传部分,不得不说lftp很强大,抛弃ftp吧####
  46. lftp $FTP_HostName -u $FTP_UserName,$FTP_PassWord << EOF
  47. cd $FTP_BackupDir
  48. mrm $OldWWWBackup
  49. mrm $OldDBBackup
  50. mput $TodayWWWBackup
  51. mput $TodayDBBackup
  52. bye
  53. EOF

脚本下载地址:http://vps.lucktang.com/sh/backup.sh

下载脚本,将脚本放到/root/ 下面,按上面的注释修改脚本中的参数,并保存,如果不熟悉vi或者nano编辑器,可以用winscp.

为脚本添加执行权限,执行:

  1. chmod +x /root/backup.sh

添加定时执行,在crontab中加入:

  1. echo  "0 3 * * * /root/backup.sh"  >> /var/spool/cron/root

查看是否添加成功

  1. crontab -e

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

  • 我的微信
  • 使用微信扫一扫
  • weinxin
  • IT运维交流群
  • 使用QQ扫一扫
  • weinxin

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: