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