写一个脚本
#!/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这个数据库,当然数据库里要存在这个数据库哦
4017

被折叠的 条评论
为什么被折叠?



