linux 将远程mysql复制,在线备份MySQL及远程copy到远程备份服务器shell脚本

该脚本实现了以下几点功能:

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值