MySQL自动备份可通用shell脚本

本文和大家分享的主要是 mysql数据库 中,自动备份可通用shell 脚本的相关内容,一起来看看吧,希望对大家有所帮助。
  最近在整理服务器的脚本,发现以前写的MySQL 每天自动备份脚本写的不太好,就重新写了一个:
  #!/bin/bash
  #### 目录环境的配置 ####
  export datetime=`date +"%Y%m%d"`
  export mysqlbin_dir="/usr/local/mysql/bin"
  export datadir="`$mysqlbin_dir/mysql -h localhost -uroot -A -Bse "show variables like 'datadir';" |awk '{print $2}'`"
  export mysql_backup="/data/backup/mysql_backup"
  export masterbakdir="$mysql_backup/masterbakdir"
  export database="database"
  if [ ! -e "$masterbakdir/"$datetime"" ];then
  mkdir -p $masterbakdir/"$datetime"
  fi
  if [ ! -e "$mysql_backup/logs" ];then
  mkdir -p "$mysql_backup/logs"
  fi
  #### 记录主库库状态 ####
  $mysqlbin_dir/mysql -h localhost -A -e "select now();show master status\G;" |tee -a $masterbakdir/"$datetime"/masterstat_${datetime}.log
  echo "============================ start mysqldump `date`" | tee -a $masterbakdir/"$datetime"/masterstat_${datetime}.log
  ####mysqldump####
  $mysqlbin_dir/mysqldump --allow-keywords --opt $database > $masterbakdir/$database-$datetime.sql
  if [ $? -eq 0 ]
  then
  echo "`date` database backup success" |tee -a $masterbakdir/"$datetime"/masterstat_${datetime}.log
  else
  echo "`date` database backup fail" |tee -a $masterbakdir/"$datetime"/masterstat_${datetime}.log
  fi
  echo "============================ end mysqldump `date`"|tee -a $masterbakdir/"$datetime"/masterstat_${datetime}.log
  #### 删除 30 天前的备份,并且做日志 #####
  find $masterbakdir -type f -ctime +30 -name "$database*" -exec rm -vf {} \; >> $mysql_backup/logs/free-${datetime}.log
  find $mysql_backup/logs -type f -ctime +30 -name "free-*" -exec rm -vf {} \;
  然后再crontab 中添加定时,一般都是在没什么人使用时没有数据写入时,因为备份是要确保数据同步要加只读锁,比如每天凌晨 4 点:
  00 04 * * * /usr/local/scripts/master_dbbak.sh
  在这里要注意的是如果是需要备份整个库,势必就有备份到mysql 库,那么 mysqldump 就要添加 --events --ignore-table=mysql.event 参数,用来忽略 mysql.event 这张表,不然 mysqldump 后就会有警告:
  Warning: Skipping the data of table mysql.event. Specify the --events option explicitly
  如果数据多时会增加不必要的系统开销,mysql.event 表记录的是当前库中创建的事件,在 mysql 没有启用时,一般是空的。
  这个是一个基础脚本,以后还可以在这个基础上在添加上备份失败发邮件等等。
来源:Linux 公社
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值