在线备份MySQL及远程copy到远程备份服务器shell脚本
2015-11-03 16:19
876 查看
该脚本实现了以下几点功能:
1、在线备份mysql数据库;
2、将备份的日志存入日志文件;
3、压缩数据备份文件;
4、将压缩后的文件远程ftp到备份服务器;
5、删除本地备份超过7天的数据主要是防止因备份导致生产服务器磁盘空间的非正常增长带来性能瓶颈问题。
具体实现shell如下所示:
#!/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/***back
LogFile=/home/imu/db-backup/***back/mysqlbak.log
DATE=`date +%Y%m%d%H%M`
DumpFile=***data$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 "***data*" -mtime +7 -exec rm {} \;
echo $(date +"%y-%m-%d %H:%M:%S") delete old file done >> $LogFile
#验证结果
ls -al $DumpFile >> $LogFile
1、在线备份mysql数据库;
2、将备份的日志存入日志文件;
3、压缩数据备份文件;
4、将压缩后的文件远程ftp到备份服务器;
5、删除本地备份超过7天的数据主要是防止因备份导致生产服务器磁盘空间的非正常增长带来性能瓶颈问题。
具体实现shell如下所示:
#!/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/***back
LogFile=/home/imu/db-backup/***back/mysqlbak.log
DATE=`date +%Y%m%d%H%M`
DumpFile=***data$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 "***data*" -mtime +7 -exec rm {} \;
echo $(date +"%y-%m-%d %H:%M:%S") delete old file done >> $LogFile
#验证结果
ls -al $DumpFile >> $LogFile
相关文章推荐
- 小心服务器内存居高不下的元凶--WebAPI服务
- 运维入门
- Linux5.9无人值守安装
- 数据中心和云未来的十二大趋势
- 用vsftp快速搭建ftp服务器
- Linux快速构建apache web服务器
- 服务器监控策略浅谈
- 如何降低服务器采购成本 原理分析
- 建议的服务器分区办法
- 服务器托管六大优势分析
- Erlang实现的一个Web服务器代码实例
- 服务器技术全面解析
- Ruby简明教程之方法(Method)介绍
- 保护DNS服务器的几点方法小结
- 我国成为全球第二大服务器消费国
- 服务器 安全检查要点[星外提供]
- 服务器应用自动重新启动IIS批处理[原创]_DOS/BAT_脚本之家
- FTP 服务器关于权限的问题
- 批处理设置windows服务器的代码ThecSafe1.9.4第1/3页