使用mysqldump自动备份mysql并上传数据到ftp
发布时间:2020-12-15 07:11:57 所属栏目:安全 来源:网络整理
导读:今天PHP站长网 52php.cn把收集自互联网的代码分享给大家,仅供参考。 #!/bin/bash# Author: Edward.Zhou -- [email?protected]# Purpose: 使用mysqldump自动备份mysql并上传数据到ftp# Created: 2015/7/25NOWDATE=`date +
以下代码由PHP站长网 52php.cn收集自互联网 现在PHP站长网小编把它分享给大家,仅供参考 #!/bin/bash # Author: Edward.Zhou -- <[email?protected]> # Purpose: 使用mysqldump自动备份mysql并上传数据到ftp # Created: 2015/7/25 NOWDATE=`date +%Y-%m-%d` OLDDATE=`date +%Y-%m-%d -d '-15 days'` FTPOLDDATE=`date +%Y-%m-%d -d '-30 days'` NOWTIME=`date +%Y%m%d%H%M%S` MYSQLDUMP=/usr/bin/mysqldump SOCKET=/var/lib/mysql/mysql.sock #建立备份基本目录环境 BACKUPDIR=/backup/mysqldb [ -d ${BACKUPDIR} ] || mkdir -p ${BACKUPDIR} [ -d ${BACKUPDIR}/${NOWDATE} ] || mkdir ${BACKUPDIR}/${NOWDATE} [ ! -d ${BACKUPDIR}/${OLDDATE} ] || rm -rf ${BACKUPDIR}/${OLDDATE} #mysqldump备份 USERNAME=backup PASSWORD=backup DATABASENAME=(mysql test) for DBNAME in ${DATABASENAME[@]}; do ${MYSQLDUMP} --opt --add-drop-database --tz-utc=true --flush-logs --events -u${USERNAME} -p${PASSWORD} -S${SOCKET} ${DBNAME} | gzip -c -9 > ${BACKUPDIR}/${NOWDATE}/${DBNAME}-backup-${NOWTIME}.sql.gz logger "${DBNAME} has been backup successful - ${NOWDATE}" /bin/sleep 5 done #上传备份至FTP HOST=1.1.1.1 FTP_USERNAME=backup FTP_PASSWORD=backup cd ${BACKUPDIR}/${NOWDATE} ftp -i -n -v << EOF open ${HOST} user ${FTP_USERNAME} ${FTP_PASSWORD} bin cd ${FTPOLDDATE} mdelete * cd .. rmdir ${FTPOLDDATE} mkdir ${NOWDATE} cd ${NOWDATE} mput * bye EOF #使用备用方式删除旧备份文件 # find ${BACKUPDIR} -type f -ctime +2 -exec rm -fr {} ; # find ${BACKUPDIR} -empty -exec rm -fr {} ; 以上内容由PHP站长网【52php.cn】收集整理供大家参考研究 如果以上内容对您有帮助,欢迎收藏、点赞、推荐、分享。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |