VPSMVP部落 - 便宜VPS|VPS优惠|VPS测评|美国VPS|外贸VPS|VPS教程|域名优惠|主机优惠

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

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

 

一,安装所需程序

  [notification type=”info”] yum install -y mutt vixie-cron[/notification]

二,设置mutt发信参数

[notification type=”info”] $ vim ~/.muttrc[/notification]

写入下面的内容
[notification type=”info”]

  1. set envelope_from=yes
  2. set from=bak@diavps.com
  3. set realname=”DiaBak”
  4. set use_from=yes

[/notification]
然后设置要接收邮件的Gmail,把bak@diavps.com加入白名单。

三,设置脚本

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

以每天执行为例

[notification type=”info”] $ vim /etc/cron.daily/diabsk.sh

写入下面的内容
[notification type=”info”]

  1. #!/bin/bash
  2. # SETTING
  3. TOEMAIL=”bak@diavps.com”;
  4. COMMENT=’blog database backup’
  5. DIR=’wordpress’
  6. # END SETTING
  7. TMP=’/tmp/diabak/’${DIR}
  8. ATTTMP=’/tmp/diabakatt/’${DIR}
  9. rm -rf $TMP
  10. mkdir -p $TMP
  11. cd $TMP
  12. # Put files what you want to backup to $TMP
  13. # Don’t change anything below
  14. YYYYMMDD=`date +%Y%m%d`
  15. SUBJECT=’DiaBak_of_’${DIR}’_’${YYYYMMDD};
  16. rm -rf $ATTTMP
  17. mkdir -p $ATTTMP
  18. cd $ATTTMP
  19. tar zcPf backup.tar.gz $TMP
  20. rm -rf $TMP
  21. split -b 20m -a 3 -d backup.tar.gz ${SUBJECT}.part
  22. rm -f backup.tar.gz
  23. for file in *
  24. do
  25.         echo $COMMENT | mutt -a $file -s $SUBJECT $TOEMAIL
  26.         sleep 30s
  27. done
  28. rm -rf $ATTTMP

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

四,导出数据库的命令。

1.备份单个数据库
[notification type=”info”]
mysqldump –user=user –password=password –lock-all-tables dbname > backup.sql[/notification]

2.备份多个数据库
[notification type=”info”]
mysqldump –user=user –password=password –lock-all-tables –databases dbname1 dbname2 > backup.sql[/notification]

3.备份所有数据库
[notification type=”info”]
mysqldump –user=user –password=password –lock-all-tables –all-databases > backup.sql[/notification]

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

五,重新组合备份的文件

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

六,其他

测试了一个600多M的文件,以20M的大小分成了31个包,通过脚本发送,用时十几分钟,期间网速保持在5Mbps到10Mbps之间,本机还有足够的带宽,这个应该是GMAIL的上限了。

有些邮件需要过一个多小时才在Gmail显示出来。31个包全部收到。
如果哪位发现有比Gmail更适合备份的邮箱,期待与大家分享。

转载请注明文章来源:VPSMVP部落 - 便宜VPS|VPS优惠|VPS测评|美国VPS|外贸VPS|VPS教程|域名优惠|主机优惠 » Linux VPS自动备份文件并发送到Gmail (适用G级数据的备份)

分享到:

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址