干货日志

记录和分享技术成长的脚步

Linux服务器每日备份数据

目录
[隐藏]

1.简述

作为一个站长来说,服务器备份是一个必须要做的事情,因为我们也许会在某一天遇到一个不可抗拒的事情,数据没有备份,那么服务器一旦出现问题,将会万劫不复,所以我们现在来讨论一下每日备份的问题。

2.备份

备份有很多种,我这里只提到FTP备份和网盘备份。

2.1.FTP备份

如果很早以前在GoDaddy买过域名并且没有迁移过的话都会得到一个10G的空间,一些主机商,例如BuyVM也给每个用户分配了一个5G的备份空间,网上也有很多免费的空间,所以备份的位置并不是太重要。

接下来是把所有的文件和数据库导出来,我这里有已经有人写好的代码,大家可以把这个代码保存成shell文件,一般都是保存成AutoBackupToFtp.sh,放到root目录下。代码如下:

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

#定义数据库的名字和旧数据库的名字
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 `/usr/local/mysql/bin/mysql -u$MYSQL_USER -p$MYSQL_PASS -B -N -e 'SHOW DATABASES' | xargs`; do
    (/usr/local/mysql/bin/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的文件夹,临时备份文件会保存到这个位置。

所有设置完毕以后可以运行一下下面的命令来测试一下。

sh /root/AutoBackupToFtp.sh

如果没有问题就可以设置每天备份了。

chmod +x /root/AutoBackupToFtp.sh  #赋予运行权限
crontab -e  #设置自动任务

运行完以上的脚本以后会要求输入提供运行程序的时间和脚本。请按照以下格式输入

00 00 * * * /root/AutoBackupToFtp.sh

00 00可以换成其他时间,格式为分钟/小时。输入完毕以后保存退出。

如果流量比较大的话可以安装一个定时FTP同步软件,自动把FTP上的备份文件下载下来。

2.2.网盘备份

网盘备份的好处就是不用自己到处去找备份空间了,直接使用网盘就可以操作了。这里介绍两个最出名的网盘,一个是国内的百度网盘,一个是国外最出名的Dropbox。

2.2.1.百度网盘

有oott123朋友已经把代码写好放到github上了,具体的操作方法上面也都有,主要是利用百度云的API来进行操作备份的,我就不多介绍了。

项目地址:http://oott123.github.com/bpcs_uploader/

2.2.2.Dropbox

我搜索了下网络,有两种方法,一种是直接代码的方法,一种是像百度API那种,推荐第二种,因为第一种年代有点久远了。

直接代码:http://www.oschina.net/code/snippet_97995_11538

API传输:http://jalena.bcsytv.com/archives/1099

  1. yiluyingxiao说道:

    提前祝您新年快乐。
    乙未年(羊)冬月十九 2015-12-29

发表评论

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

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据