自动备份文件并发送到Gmail (适用G级数据的备份)
一,安装所需程序
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 settingtmp=’/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 $atttmptar zcpf backup.tar.gz $tmp
rm -rf $tmp
split -b 20m -a 3 -d backup.tar.gz ${subject}.part
rm -f backup.tar.gzfor file in *
do
echo $comment | mutt -a $file -s $subject $toemail
sleep 30s
donerm -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更适合备份的邮箱,期待与大家分享。