文章地址:http://www.hostloc.com/thread-114247-1-1.html
=================================================================================
另外一贴是以前登陆网站上传备份,不那么好用,而且使用网站上传有限制.
我这个备份方案是直接使用dropbox同步,如果想实时同步就一直守护dropbox进程,会占用一定资源.推荐小内存的VPS和我一样使用cron定时备份.
1.linux上安装dropbox
32位linux
- wget -O dropbox.tar.gz http://www.dropbox.com/download?plat=lnx.x86
64位linux
- wget -O dropbox.tar.gz http://www.dropbox.com/download?plat=lnx.x86_64
解压:
- tar xzvf dropbox.tar.gz
第一次运行生成host_id
- ~/.dropbox-dist/dropboxd &
生成id后,将host_id替换下面链接后面的字符在浏览器打开,输入你的帐号密码就绑定机器了.
- https://www.dropbox.com/cli_link?host_id=XXXXXXXXXXXXXXXXXXX
2.建立连接备份网站
正式开始同步你的网站,通过ln软链接你所有要备份的目录,例如:
- cd ~/Dropbox
- ln -s /home/wwwroot/html
- ln -s /home/wwwroot/htdocs
- ...
开始运行同步,美国的vps同步速度非常快的,1G的html文件,只花了几分钟全部同步完成
- ~/.dropbox-dist/dropboxd &
3.为了节省资源,可以不使用实时同步,只定时打开同步一天的文件再关掉以节省资源.
先关掉同步:
- killall dropbox
编写定时同步脚本:
- vi backup.sh
代码如下:
- #!/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 +x backup.sh
- crontab -e
每天4点开始同步,5点关闭同步.
其实一般每天更新数据不多不用打开这么长时间,我自己用的一天只打开10分钟,这个根据各人每天更新的数据量自己来设置.
- 0 4 * * * sh /root/backup.sh restart
- 0 5 * * * sh /root/backup.sh stop
4.干脆把我从网上找的备份数据库的脚本一并贡献出来,适合懒人使用
- vi bakmysql.sh
脚本如下:
- #!/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
5.删除卸载dropbox方法:
- killall dropbox
- rm -rf .dropbox .dropbox-dist Dropbox dropbox.tar.gz dbmakefakelib.py dbreadconfig.py