备份,其实一句话解释就是通过 cron 定期执行脚本,对需要备份的目录使用 tar进行打包,然后 sendmail 发到邮箱。
这里的操作系统是 CentOS,其它系统应该也是大同小异。以下便是本次行动的流水帐 :)
Sendmail 相关
因为系统里原生没有安装 sendmail,于是
yum install sendmail # 安装
service sendmail start # 启动服务
chkconfig sendmail on # 开启自动启动
因为只想使用发信功能,所以也不用花时间改配置(收信功能的默认配置是只接受本地邮件)。确定防火墙允许 25 端口后,就可以使用下面的命令直接发送邮件了。
# 使用交互模式(使用只包含一个句点的行结束正文并发送)
mail <收件人>
# 命令行直接发送
echo <正文> | mail -s <主题> <发件人>
使用这种方法发出的邮件显示发件人地址为「<用户名>@<主机名称>」。因为 sendmail 只支持纯文本,所以需要借助 uuencode 来编码附件,于是:
# 只包含附件
uuencode <文件路径> <文件显示名称> | mail -s <主题> <收件人>
# 正文和附件
(echo <正文>; uuencode <文件路径> <文件显示名称>) | mail -s <主题> <收件人>
备份脚本
编写 Shell 脚本实现对 Web 目录的备份和发送工作,因为博客使用的是 SQLite 数据库,直接打包即可,不需要先用 mysqldump 导出。(新手上路,表示快被引号什么的弄疯了,于是大多数情况下都为变量加上了引号。另外邮件正文纯属无聊,完全可以不加 = =)
#!/bin/sh
# 备份文件存放目录
BACKUP_DIR="/path/to/backup/directory"
# 备份文件邮件接收地址
BACKUP_MAIL_RECEIVER="example@example.com"
# =====================================
# 保证目录存在
[ ! -d "$BACKUP_DIR" ] && mkdir -p "$BACKUP_DIR"
# 需要备份的路径
WEB_DIR="/path/to/web/root"
BACKUP_DATE="`date +%Y-%m-%d`"
BACKUP_FILE_NAME="$BACKUP_DATE.tar.gz"
BACKUP_FILE_FULLNAME="$BACKUP_DIR/$BACKUP_FILE_NAME"
cd $WEB_DIR
tar czpf "$BACKUP_FILE_FULLNAME" *
BACKUP_MAIL_SUBJECT="VPS Backup: $BACKUP_DATE"
BACKUP_MAIL_MESSAGE=$(
echo "Sir,";
echo "";
echo "Backup file $BACKUP_FILE_FULLNAME created.";
)
(echo "$BACKUP_MAIL_MESSAGE"; uuencode "$BACKUP_FILE_FULLNAME" "$BACKUP_FILE_NAME") \
| mail -s "$BACKUP_MAIL_SUBJECT" "$BACKUP_MAIL_RECEIVER"
保存后给脚本加上执行权限,就可以直接运行试一下,应该会有邮件发到邮箱了。
chmod u+x <脚本名>
定时执行
定时执行肯定就是 cron 了,这个不用多说,直接 crontab -e
然后添加一行:
0 0 * * 2 /path/to/script
就大功告成鸟~从此,每周二午夜就会有一封谜之信件安静地躺到你的邮箱里……
No comments:
Post a Comment