转自:http://blog.sina.com.cn/s/blog_5e7987700100cz53.html
LINUX备份MYSQL-通过邮件自动发送到指定邮箱
1.所需要软件
mutt LINUX下命令行邮件工具,可用来接收和发送邮件
sendmail/postfix LINUX下邮件服务器,所有邮件通过本机发送出去
mysqldump 备份MYSQL数据库的程序
2.mutt参数介绍
-a <filename> 附件
-s <subject> 主题
例子:
echo “你好,祝你愉快!” | mutt -a /etc/passwd -s “LINUX发送带附件的邮件” hugwww@163.com
说明:echo打印的内容为邮件正文,发送密码文件passwd到邮箱hugwww@163.com
3.脚本
测试备份的数据库名:
scriptdev2 realmd mmfpm mangos characters
查看数据库使用的字符集
show variables like “char%”;
utf8
建立备份脚本
vi /root/send-mysql-data.sh
#!/bin/bash
#Power by hugwww 2009-4-11
#set time format
date=`date -d “%m”date -d today +”%Y-%m-%d-%H:%M”`
echo $date
#定义数组
db_array=(scriptdev2 realmd mmfpm characters mangos)
#取数组无元素个数
lenArray=${#db_array[@]}
#循环列出数组元素
i=0
while [ $i -lt $lenArray ]
do
#执行备份
mysqldump -uroot -ppassw0rd –default-character-set=utf8 –opt –extended-insert=false \
–triggers -R –hex-blob -x ${db_array[$i]} > /opt/db-backup/everyday/${db_array[$i]}-$date.sql;
# echo ${db_array[$i]}
let i++
done
#将所有SQL文件压缩到一个文件
tar cvzf /opt/db-backup/mysql-data-$date.tar.gz /opt/db-backup/everyday/*$date.sql
#发送备份文件到邮箱
echo “$date 数据库备份文件” | mutt -a /opt/db-backup/mysql-data-$date.tar.gz -s “mangos数据库备份” hugwww@163.com
echo “$date 备份成功并发送到指定邮箱” >> /opt/db-backup/backup.log
exit
完成
评论