首先要有个DROPBOX账户。
链接,戳
一直以来,使用美帝VPS建站,由于网速等多方面原因,面临着备份困难、下载困难的难题,而且还要面临故障啊、商家跑路啊等等数据丢失的风险,前段 时间DS不是数据都木有了么。现在就来讲一下解决这个问题的方法,早些时候有用脚本通过FTP来备份的,例如使用godaddy域名附带的免费空间或者另 外单独购买备份空间,但有时并不好用;也有两台VPS同步备份的,这个花费有点高。而现在使用DropBox来进行同步备份,全自动化,非常好用,去年就 有过类似的介绍,但很多都不详细,搜集了网上的方法,特别整理出来,所有过程都有详细注明。
————————————————————————————————————
DropBox:Dropbox是一个提供同步本地文件的网络存储在线应用。支持在多台电脑多种操作中自动同步。(注:要使用https才能访问,至于http不能访问的原因,都懂的)
容量大小:初 始的免费容量是2G,完成上手任务后可以多增加250M。用官方提供的邀请链接,每一个成功邀请注册可获赠500M,可以最大扩容到18.25G。邀请那 个了比较麻烦,在淘宝上有专门以扩容为业务的店铺,大概RMB8元左右就可以了。此外,偶尔官方会有些活动,例如今年2月有一个安装beta版客户端导入 图片送5G的活动,不过现在已经失效了。
————————————————————————————————————
一、安装Dropbox linux客户端:(官方简易教程:点击我前往)
ssh登陆,在root目录下输入以下命令,视版本不同而选择:(注:code中已包含cd到root根目录的命令,而且只有在root根目录下后续步骤才能生效)
32-bit:
|
cd ~ && wget -O – “http://www.dropbox.com/download?plat=lnx.x86″ | tar xzf - |
|
64-bit:
|
cd ~ && wget -O – “http://www.dropbox.com/download?plat=lnx.x86_64″ | tar xzf - |
|
下载后已自动解压,不需要再执行解压命令。
二、Dropbox与机器绑定
执行以下命令:
|
~/.dropbox-dist/dropboxd & |
|
第 一次执行会生成“host_id”,这机器与Dropbox进行绑定的唯一字符串,提示的信息是一个链接,而且会重复滚动出现直到绑定完成。复制这个链接 在浏览器里访问,输入Dropbox帐户和密码就可以了,输入后会自动跳转到Dropbox主界面并且会有绑定成功的提示,此时在ssh客户端里也会有提 示并且停止滚动,再按回车键就完成绑定。
(注:官方的运行命令结尾没有“&”这个符号,在centos下运行会出现ssh冻结无反应的情况,据称Debian也会。实际上守护进程已经在运行了。)
三、建立目录软链接
在 root目录下生成的“Dropbox”文件夹(linux文件夹名称区分大小写的),就是Windows里叫做“同步目录”的文件夹,只要把文件放置在 里面就会同步。在未同步之前,里面有一个文件夹“.dropbox.cache”和一个文件“.dropbox”。当然我们不可能把网站放置到这里,因此 我们需要在里面建立软链接就行了,使用ln命令建立软链接(软链接其实就是windows里的快捷方式),格式是:ln –s 源文件 目标文件,我可以先进入“Dropbox”文件夹,免去每次都需要输入目标文件的麻烦。过程如下:
|
cd ~/Dropbox |
ln -s /home/wwwroot |
|
释义:进入“Dropbox”文件夹,建立/home/wwwroot/ 文件夹的软链接。运行这两个命令后会在“Dropbox”文件夹下生成一个名为“wwwroot”的软链接。如果网站放在不同地方的话,那么就建立多个软链接就好。
四、运行同步守护进程,同步网站数据
输入以下命令,这个命令就是之前绑定“host_id”的那个命令。
|
~/.dropbox-dist/dropboxd & |
|
运 行此命令后,视数据大小和网络环境而定,反正美帝的VPS同步都很快,会在浏览器里的Dropbox文件管理界面里看到同步的文件夹。同时,在 “Events(活动)”里看到同步记录,记录里有文件数量和文件夹数量,机器与Dropbox帐户的绑定日志也会记录在里面,这个其实就是 Dropbox的帐户活动记录。
五、定时同步,节约内存资源
运行守护进程是要占用一定内存的,为了节约这部分内存,可以通过定时运行脚本来控制。过程如下:
在第三步是进入了“Dropbox”文件夹的,我们一般把脚本放在root目录下,因此需要回到root根目录,执行:
首选需要关掉守护进程,运行:
编写定时同步脚本:
用vi编辑器新建backup.sh目录,运行后会进入vi编辑器,此时按“I”键进入编辑模式,复制以下代码粘贴进去,按ESC键退出编辑模式,开启大写锁定状态(按“Caps Lock”键),再按两次“Z”键即自动保存并退出vi编辑器。
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
|
#!/bin/sh |
start() { |
echo starting dropbox |
/root/.dropbox-dist/dropboxd & |
} |
stop() { |
echo stoping dropbox |
pkill dropbox |
} |
case “$1″ in |
start) |
start |
;; |
stop) |
stop |
;; |
restart) |
stop |
start |
;; |
esac |
|
继续运行以下命令,用“chmod”命令为“backup.sh”添加可执行权限:
编写周期性执行指令:
“crontab”命令运行后会自动调用内置的vi编辑器进行编辑,按“I”键进入编辑模式,复制以下两行指令代码并粘贴。
|
0 4 * * * sh /root/backup.sh restart |
0 5 * * * sh /root/backup.sh stop |
|
上 面的意思是在每天4点开始同步,5点关闭同步,一个小时一般都够用,除非网站特别大。完成后按“ESC”退出编辑模式,开启大写锁定状态,再按两次“Z” 键即自动保存并退出vi编辑器。附:“crontab -l” 列出目前的时程表,“crontab -r” 删除目前的时程表,“crontab”指令的详细介绍可以参考这里>>点我传送,可自行调整同步时间。查看系统当前时间的命令是“date”。
六、同步mysql数据库的脚本
创建数据库备份脚本:
按“I”键进入编辑模式,复制以下代码并粘贴(文字部分填写需填写完好才行),按“ESC”退出编辑模式,开启大写锁定状态,再按两次“Z”键即自动保存并退出vi编辑器。
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
32 |
33 |
34 |
35 |
36 |
37 |
38 |
39 |
40 |
41 |
42 |
43 |
44 |
45 |
46 |
47 |
48 |
49 |
50 |
51 |
52 |
53 |
54 |
55 |
56 |
57 |
58 |
59 |
60 |
61 |
62 |
63 |
|
#!/bin/bash |
DBName=修改为数据库名 |
DBUser=修改为数据库用户名 |
DBPasswd=修改为数据库密码 |
BackupPath=/root/Dropbox/ |
LogFile=/root/db.log |
DBPath=/usr/local/mysql/var/ #备份的数据库目录 |
#BackupMethod=mysqldump |
#BackupMethod=mysqlhotcopy |
#BackupMethod=tar |
|
NewFile=”$BackupPath”db$(date +%y%m%d).tgz |
DumpFile=”$BackupPath”db$(date +%y%m%d) |
OldFile=”$BackupPath”db$(date +%y%m%d –date=’5 days ago’).tgz #自动删除5天前的备份 |
echo “——————————————-” >> $LogFile |
echo $(date +”%y-%m-%d %H:%M:%S”) >> $LogFile |
echo “————————–” >> $LogFile |
#Delete Old File |
if [ -f $OldFile ] |
then |
rm -f $OldFile >> $LogFile 2>&1 |
echo “[$OldFile]Delete Old File Success!” >> $LogFile |
else |
echo “[$OldFile]No Old Backup File!” >> $LogFile |
fi |
if [ -f $NewFile ] |
then |
echo “[$NewFile]The Backup File is exists,Can’t Backup!” >> $LogFile |
else |
case $BackupMethod in |
mysqldump) |
if [ -z $DBPasswd ] |
then |
mysqldump -u $DBUser –opt $DBName > $DumpFile |
else |
mysqldump -u $DBUser -p$DBPasswd –opt $DBName > $DumpFile |
fi |
tar czvf $NewFile $DumpFile >> $LogFile 2>&1 |
echo “[$NewFile]Backup Success!” >> $LogFile |
rm -rf $DumpFile |
;; |
mysqlhotcopy) |
rm -rf $DumpFile |
mkdir $DumpFile |
if [ -z $DBPasswd ] |
then |
mysqlhotcopy -u $DBUser $DBName $DumpFile >> $LogFile 2>&1 |
else |
mysqlhotcopy -u $DBUser -p $DBPasswd $DBName $DumpFile >>$LogFile 2>&1 |
fi |
tar czvf $NewFile $DumpFile >> $LogFile 2>&1 |
echo “[$NewFile]Backup Success!” >> $LogFile |
rm -rf $DumpFile |
;; |
*) |
service mysql stop >/dev/null 2>&1 |
tar czvf $NewFile $DBPath$DBName >> $LogFile 2>&1 |
service mysql start >/dev/null 2>&1 |
echo “[$NewFile]Backup Success!” >> $LogFile |
;; |
esac |
fi |
echo “——————————————-” >> $LogFile |
|
保存好脚本后别忘了加上可执行权限,你也可以定时运行哦,执行后自动在同步目录里生成备份,守护进程运行后则自动同步了。
七、卸载dropbox方法
停止守护进程,删除目录就好了。分别执行以下命令:
|
killall dropbox |
rm -rf .dropbox .dropbox-dist Dropbox dropbox.tar.gz dbmakefakelib.py dbreadconfig.py |
|
八、重装系统或者转移后如何使用Dropbox恢复VPS数据
1、进行上面第一步和第二步后,就会自动在同步目录“Dropbox”里出现原先备份的文件夹,注意,这不是软链接,这是同步过来的文件。
2、稍等片刻,等同步完成后手工移动到你想要放置数据的目录,然后重新在同步目录建立一下软链接就好了。
注: 过程实际上是先同步数据到同步目录里,转移文件夹时在Dropbox服务器上自动执行了删除操作,当建立软链接后,又开始同步Dropbox到服务器上。 如果想节约流量,那么可以先结束掉守护进程,再建立软链接,在Dropbox的网页操作界面上点击“回收站”那个图标,显示出已经删除的数据,右键选择 “恢复”即可恢复回来,那么同步时只是对比,不会再上传。