日前VPS盛行,由于国内备案的原因,很多用户购买了海外的VPS,我站也位于美国的VPS,但是海外VPS存在很多不确定因素,站长们每天都担心二天一起床,自己的网站就打不开了。所以我们需要及时对自己的服务器进行备份。
准备:一个FTP,空间越大越好。用于存放我们的文件和数据库。
原理:每天定时把网站和数据库打包成压缩文件,再通过LFTP将压缩文件上传到远程的FTP,从而实现远程备份,当然你可以设置自动删除较早的备份文件。
步骤1.安装LFTP,CentOS直接执行:
yum install lftp
Debian执行:
apt-get install lftp
步骤2.安装crontab,运行:yum install vixie-cron ,yum install crontabs
说明:
vixie-cron软件包是cron的主程序;
crontabs软件包是用来安装、卸装、或列举用来驱动 cron 守护进程的表格的程序。
步骤3.在VPS建立/home/backup/目录用于存放打包后的网站和数据库。
在FTP上建立backup目录,用于上传备份文件。
步骤4.编写脚本bakcup.sh(根据注释进行一些修改,例如要备份的文件夹,数据库用户和密码):
#!/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=588w.net
Backup_Dir2=dir2
Backup_Dir3=dir3
Backup_Dir4=dir4
######~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=username //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
rm $OldWWWBackup
rm $OldDBBackup
###删除3天前的备份###
cd /home/backup/
###下面为自动上传部分####
lftp $FTP_HostName -u $FTP_UserName,$FTP_PassWord << EOF
cd $FTP_BackupDir
mrm $OldWWWBackup
mrm $OldDBBackup
mput $TodayWWWBackup
mput $TodayDBBackup
bye
EOF
步骤5.将上面的脚本放到/root/bakcup.sh下面,然后为它添加执行权限,chmod +x /root/backup.sh
步骤6.设置自动运行:
执行:crontab -e 添加定时执行,
键入0 3 * * * /root/backup.sh 每天凌晨3点执行。
保存退出(编辑后按下ESC,再按下冒号:x,回车就可以保存退出)
步骤7. 运行crontab服务,执行service crond start //启动服务
大功告成,安心的睡一觉,第二天起床如果发现FTP上面backup中多出了N个压缩包和SQL文件则表示备份成功。我的切图如下:

vps自动备份