服务器多了,网站也越来越多,总觉得不整个备份心里放不下心,并且有好几次rm的操作失误,造成难以挽回的损失。并且大多数的VPS提供商是不提供自动备份功能或者此功能收费价格略高。所以自己还是有必要把这个工作落实一下,说不定哪天就用到了。

使用的备份空间我自己是用的是Godaddy的Online Storage,优点在于,我的VPS都是美国服务商,选用Godaddy的空间传输速度比较有保证,另外最关键的价格也能接受,100G空间一年下来不到30美金,鉴于目前美金对人民币的汇率,这个价格我觉得已经相当优惠了。

脚本很简单,大家可以根据自己的需要修改相关内容,此处主要借鉴了Linux VPS自动备份:脚本上传FTP及RSYNC增量备份,我主要是针对debian系统稍微调整了一句,大家也可以参考一下。

#!/bin/bash
#你要修改的地方从这里开始
MYSQL_USER=root                    #mysql用户名
MYSQL_PASS=123456                  #mysql密码
MAIL_TO=admin@xxx.com              #数据库发送到的邮箱
FTP_USER=yonghuming                #ftp用户名
FTP_PASS=123456                    #ftp密码
FTP_IP=*.*.*.*                     #ftp地址
FTP_backup=/www/backup           #ftp上存放备份文件的目录,这个要自己得ftp上面建的
WEB_DATA=/home/wwwroot             #要备份的网站数据
#你要修改的地方从这里结束

#定义数据库的名字和旧数据库的名字
DataBakName=Data_$(date +"%Y%m%d").tar.gz
WebBakName=Web_$(date +%Y%m%d).tar.gz
OldData=Data_$(date -d -5day +"%Y%m%d").tar.gz
OldWeb=Web_$(date -d -5day +"%Y%m%d").tar.gz
#删除本地3天前的数据
rm -rf /home/backup/Data_$(date -d -3day +"%Y%m%d").tar.gz /home/backup/Web_$(date -d -3day +"%Y%m%d").tar.gz
cd /home/backup
#导出数据库,一个数据库一个压缩文件
for db in `mysql -u$MYSQL_USER -p$MYSQL_PASS -B -N -e 'SHOW DATABASES' | xargs`; do
    (mysqldump -u$MYSQL_USER -p$MYSQL_PASS ${db} | gzip -9 - > ${db}.sql.gz)
done
#压缩数据库文件为一个文件
tar zcf /home/backup/$DataBakName /home/backup/*.sql.gz
rm -rf /home/backup/*.sql.gz
#发送数据库到Email,如果数据库压缩后太大,请注释这行
#echo "主题:数据库备份" | mutt -a /home/backup/$DataBakName -s "内容:数据库备份" $MAIL_TO
#压缩网站数据
tar zcf /home/backup/$WebBakName $WEB_DATA
#上传到FTP空间,删除FTP空间5天前的数据
ftp -v -n $FTP_IP << END
user $FTP_USER $FTP_PASS
type binary
cd $FTP_backup
delete $OldData
delete $OldWeb
put $DataBakName
put $WebBakName
bye
END

需要注意的就是,备份目录/home/backup需要自己创建。然后在/root下创建这个AutoBackupToFtp.sh,并且赋予可执行权限

chmod +x /root/AutoBackupToFtp.sh

接下来为了能够定期自动备份,我们需要添加一个cron时钟任务
crontab –e

在文件最后添加下面一行
00 03 * * * /root/AutoBackupToFtp.sh

那个03就是凌晨3点,你可以根据自己网站访问情况自动调整,选择一个访问量比较小的时刻,不然如果网站文件过多,打包动作还是会给服务器造成一定的负担。

脚本下载:https://github.com/nonozone/TEMP/blob/master/AutoBackupToFtp.sh

Related Posts

  • SSH安装Wordpress指南 (0)
    本篇是紧接上篇基于Debian的VPS搭建LAMP指南之后,直接用SSH在VPS上安装wordpress过程。 下面还是直接在root账户下操作,不过建议各位可以新建一个普 […]
  • 黑莓桌面管理器5.0下载 (13)
    前几天,有新闻爆出有针对黑莓9000手机系统5.0的真机演示视频,现在BlackBerry Bold 9000 OS 5.0.0.90和BlackBerry Curve […]
  • 致所有中国的苍井迷 (0)
    继前几日苍井空引爆中文twitter圈以后,可以 点击此处 查看直播苍井空老师在推特被中国推友推红全过程,苍井空姐姐在其官方博客写了这篇中文的感谢声明,这里转发一下。 […]
  • 再次统计自己的tweet数据,诧异啊! (3)
    去年9月份的时候,我就用tweetstats统计了自己的twitter数据了,对比一下,相当吃惊。 […]
  • 那些年我用过的钢笔墨水 (4)
    从小时候到现在用过的钢笔墨水有很多,牌子也乱七八糟,刚才无聊搜了下,大概有这么几个。 上海碳素墨水 […]

一个回复

发表评论

电子邮件地址不会被公开。 必填项已用*标注