定时备份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这个数据库,当然数据库里要存在这个数据库哦

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值