定时备份mysql数据库

写一个脚本

#!/bin/bash
DB_NAME=$1
if [ "$DB_NAME"x == ""x ]; then
echo "you need input a db name." && exit 0
fi
MYSQL_HOME=/usr/local/mysql
MYSQL_DUMP=$MYSQL_HOME/bin/mysqldump
BACKUP_DB_DIR=/data/backup/db/$DB_NAME
if [ ! -d  "$BACKUP_DB_DIR" ]; then
mkdir -p $BACKUP_DB_DIR
fi
TIME="$(date +"%Y%m%d%H%M")"
$MYSQL_HOME/bin/mysqldump -uusername -ppassword db_psq |gzip > $BACKUP_DB_DIR/$DB_NAME-$TIME.sql.gz
find $BACKUP_DB_DIR -name "$DB_NAME*.sql.gz" -type f -mtime +30 -exec rm {} \; > /dev/null 2>&1

find $BACKUP_DB_DIR -name "$DB_NAME*.sql.gz" -type f -mtime +30 -exec rm {} \; > /dev/null 2>&1

意思是在备份目录,查$DB_NAME前缀,sql.gz后缀的文件  其中-type f表示普通文件,mtime +30表示30天前的文件 ,找到文件后执行 -exec rm {} 删除, /dev/null 2>&1 就是标准错误输出到标准输出 并扔到/dev/null,也就是可以认为扔到垃圾桶啦

将shell脚本放到/usr/local/mysql/bin目录

使用方法  /usr/local/mysql/bin/mysql_backup.sh db_name

需要定时备份的话,就配一个cron定时任务

crontab -e

30 3 * * * (/usr/local/mysql/bin/mysql_backup.sh db_name) > /dev/null 2>&1

意思是每天凌晨3点30分 备份 db_name这个数据库,当然数据库里要存在这个数据库哦

猜你喜欢

转载自jaychang.iteye.com/blog/2319480
今日推荐