首 页 » VPS管理维护 » 自动备份文件并发送到Gmail (适用G级数据的备份)

自动备份文件并发送到Gmail (适用G级数据的备份)

2010-04-22 | 浏览人数: 4,596次 | 分类: VPS管理维护 | 7条评论 | 查看评论 发表评论

一,安装所需程序

yum install -y mutt vixie-cron

二,设置mutt发信参数

$ vim ~/.muttrc

写入下面的内容

set envelope_from=yes
set from=bak@deepvps.com
set realname=”DiaBak”
set use_from=yes

然后设置要接收邮件的Gmail,把bak@deepvps.com加入白名单。

三,设置脚本
注意这几个目录
/etc/cron.hourly
/etc/cron.daily
/etc/cron.weekly
/etc/cron.monthly
这些目录下的文件可以分别每小时,每天,每周,每月自动执行一次。
如果是把脚本程序放置在上面的目录里,最好把权限设置为0700。
设置更复杂的执行条件可以使用crontab -e命令。详情请百度。

以每天执行为例

$ vim /etc/cron.daily/diabsk.sh

写入下面的内容

#!/bin/bash

# SETTING
TOEMAIL=”bak@deepvps.com”;
COMMENT=’blog database backup’
DIR=’wordpress’

# END SETTING

TMP=’/tmp/diabak/’${DIR}
ATTTMP=’/tmp/diabakatt/’${DIR}

rm -rf $TMP
mkdir -p $TMP
cd $TMP

# Put files what you want to backup to $TMP

# Don’t change anything below
YYYYMMDD=`date +%Y%m%d`
SUBJECT=’DiaBak_of_’${DIR}’_'${YYYYMMDD};

rm -rf $ATTTMP
mkdir -p $ATTTMP
cd $ATTTMP

tar zcPf backup.tar.gz $TMP
rm -rf $TMP
split -b 20m -a 3 -d backup.tar.gz ${SUBJECT}.part
rm -f backup.tar.gz

for file in *
do
echo $COMMENT | mutt -a $file -s $SUBJECT $TOEMAIL
sleep 30s
done

rm -rf $ATTTMP

需要更改的内容已经加红
TOEMAIL为接收邮件的邮箱地址。
TOEMAIL为注释邮件,以邮件正文发送。
DIR为临时目录名,建议仅使用英文和数字。
# Put files what you want to backup to $TMP,这一行下面的命令根据需要自己补充,比如备份数据库可以把SQL文件导出到$TMP目录,备份文件可以复制文件到$TMP目录。

四,导出数据库的命令。
1.备份单个数据库

mysqldump –user=user –password=password –lock-all-tables dbname > backup.sql

2.备份多个数据库

mysqldump –user=user –password=password –lock-all-tables –databases dbname1 dbname2 > backup.sql

3.备份所有数据库

mysqldump –user=user –password=password –lock-all-tables –all-databases > backup.sql

–lock-all-tables选项可以在备份期间锁定数据库防止出现变化,进而导致多个有关系的表不同步,比如A表需要引用B表,备份完A表后,B表发生了变化,之后才备份了B表,这样数据库就乱了。
备份上百M的数据库也只用了几秒而已,所以这个选项对网站运行影响不大。

五,重新组合备份的文件
Linux下
$ cat DiaBak* > bak.tar.gz
windows下
copy DiaBak_of_testfile_20100421.part001/b+DiaBak_of_testfile_20100421.part002/b bak.tar.gz
注意分卷后面会有三位数字,cat命令会按这些数字的顺序重新组合文件,所以数字不能乱。
copy命令同理,注意数字顺序。

六,其他
测试了一个600多M的文件,以20M的大小分成了31个包,通过脚本发送,用时十几分钟,期间网速保持在5Mbps到10Mbps之间,本机还有足够的带宽,这个应该是GMAIL的上限了。
有些邮件需要过一个多小时才在Gmail显示出来。31个包全部收到。
如果哪位发现有比Gmail更适合备份的邮箱,期待与大家分享。

原创文章如转载,请注明:转载自深度VPS [ http://www.deepvps.com ]
[复制本文链接发送给您的好友]
  • 上一篇:
  • 下一篇:
  • 日志信息 »

    该日志于2010-04-22 15:49由 deepvps 发表在VPS管理维护分类下, 你可以发表评论。除了可以将这个日志以保留源地址及作者的情况下引用到你的网站或博客,还可以通过RSS 2.0订阅这个日志的所有评论。

    相关日志 »

    共有7条评论 [点此发言]

    1. 1楼 Gufei 2010年04月22日 18:40

      请问这个是博主原创的吗?我准备转载。

      [回复]

      deepvps 2010年04月22日 20:20 回复:

      不是原创,我的也是转载的。但是适当的修改了一下。

      转载请加上我的链接,谢谢。

      [回复]

      Gufei 2010年04月22日 21:17 回复:

      呵呵。那我还是不转载了,不知道原始作者,我怕有麻烦。不过方法还是不错,谢谢。

      [回复]

    2. 2楼 唐朝宰相 2010年05月5日 14:17

      这种方法估计用不了多久,你的Gmail邮箱就会被ban的

      [回复]

    3. 3楼 flytwokites 2010年06月1日 17:11

      这太夸张了,google不ban你ban谁。
      我想不如搞台旧电脑放家里定时下载服务器上的定时备份文件。

      [回复]

    4. 4楼 flytwokites 2010年06月1日 17:13

      google的ban的算法还是比较强的,我以前收到一个垃圾信,上面收件人有上百,我来了一个全部回复说“大家别买它”,结果我杯具了。

      [回复]

      deepvps 2010年06月1日 22:56 回复:

      现在比较好的方法是用godaddy的免费空间异地同步备份。

      [回复]

    发表评论 »

    = 10 + 15 (防止机器人评论)

     疑问 冷笑 悲伤 坏蛋 感叹 微笑 脸红 大笑 吃惊 惊讶 困惑 酷 大声笑 恼火 古怪 转眼睛 给眼色 好主意 箭头 一般 哭了 绿人