教程集 www.jiaochengji.com
教程集 >  脚本编程  >  shell  >  正文 在线备份MySQL及复制到远程备份服务器的shell脚本

在线备份MySQL及复制到远程备份服务器的shell脚本

发布时间:2014-09-09   编辑:jiaochengji.com
在线备份MySQL及复制到远程备份服务器的shell脚本

该脚本实现如下的功能:
1、在线备份mysql数据库;
2、将备份的日志存入日志文件;
3、压缩数据备份文件;
4、将压缩后的文件远程ftp到备份服务器;
5、删除本地备份超过7天的数据主要是防止因备份导致生产服务器磁盘空间的非正常增长带来性能瓶颈问题。

文件:erpbackup.sh
 

复制代码 代码如下:
#!/bin/sh
#---------------------------------------------------------
# scriptname: erpbackup.sh
# version: 1.0 for linux
# method: backup mysqldb
# author: fengzhanhai
# history: create program V1.1 20110429 by Fengzhanhai
UserName='root'
AdminPwd='passw0rd'
DbName=erp
BakDir=/home/imu/db-backup/vpnback
LogFile=/home/imu/db-backup/vpnback/mysqlbak.log
DATE=`date +%Y%m%d%H%M`
DumpFile=vpndata$DATE.sql
GZDumpFile=$DumpFile.tgz
FtpServer=10.19.98.235
FtpTargetPath=/erp_backup/mysql
#main---------------------------------------------------------
echo $(date +"%y-%m-%d %H:%M:%S") backup begin >> $LogFile
cd $BakDir
#备份当天文件
/usr/local/mysql/bin/mysqldump -u$UserName -p$AdminPwd $DbName > $DumpFile
echo $(date +"%y-%m-%d %H:%M:%S") Dump Done >> $LogFile
#tar压缩文件
tar czvf $GZDumpFile $DumpFile >> $LogFile
#rm -f $DumpFile
echo $(date +"%y-%m-%d %H:%M:%S") $GZDumpFile compress done >> $LogFile
#上传到ftp服务器
ftp -v -n $FtpServer << END
user databack passw0rd
bin
cd $FtpTargetPath
put $GZDumpFile
bye
END
echo $(date +"%y-%m-%d %H:%M:%S") ftp $GZDumpFile compress done >> $LogFile
rm -f $GZDumpFile
#删除当前目录下7天前的文件备份文件
find $BakDir -name "vpndata*" -mtime +7 -exec  rm {} \;
echo $(date +"%y-%m-%d %H:%M:%S") delete old file done >> $LogFile
#验证结果
ls -al $DumpFile >> $LogFile

您可能感兴趣的文章:
vps自动备份shell脚本代码
在线备份MySQL及复制到远程备份服务器的shell脚本
mysql自动增量备份的例子(本地备份与远程备份)
mysql备份与同步脚本
mysql命令之备份数据库
mysql中含有视图数据库在恢复数据时视图变成数据表的解决方法
mysqldump使用binlog二进制日志进行备份的例子
使用LVM快照功能实现MySQL热备份
一个备份网站内容的shell脚本
生产环境备份shell脚本实例代码

[关闭]
~ ~