使用mysqldump自动备份mysql并上传数据到ftp

下面是编程之家 jb51.cc 通过网络收集整理的代码片段。

编程之家小编现在分享给大家,也给大家做个参考。

#!/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 {} \;

以上是编程之家(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

相关文章

系ubuntu 下面打开终端输入:sudo apt-get install sendmail...
依家我有1个软件goagent目录(大家懂得) 放在/home/gateman/...
其实我想讲的是 cp -L关于-L参数的解释:-L, --dereferenc...
原地址:http://www.rjgc.net/control/content/content.php?...
chroot,即 change root directory (更改 root 目录)。在 li...
简单解析下, stdin就是标准输入, stdout就是标准。举个例子...