检查mysql备份_Mysql数据检查备份脚本

#!/bin/bash

user=root

dateDIR=$(date -d "yesterday" +"%y-%m-%d")

mkdir -p /data/backup/mysql/data/$dateDIR

date +"%Y-%m-%d-%H:%M:%S"  >/data/backup/mysql/data/$dateDIR/MyISAMcheck.log

echo "***************************************" >>/data/backup/mysql/data/$dateDIR/MyISAMcheck.log

date +"%Y-%m-%d-%H:%M:%S"  >/data/backup/mysql/data/$dateDIR/MyISAManalyze.log

echo "***************************************" >>/data/backup/mysql/data/$dateDIR/MyISAManalyze.log

date +"%Y-%m-%d-%H:%M:%S"  >/data/backup/mysql/data/$dateDIR/MyISAMoptimize.log

echo "***************************************" >>/data/backup/mysql/data/$dateDIR/MyISAMoptimize.log

date +"%Y-%m-%d-%H:%M:%S"  >/data/backup/mysql/data/$dateDIR/InnoDBcheck.log

echo "***************************************" >>/data/backup/mysql/data/$dateDIR/InnoDBcheck.log

date +"%Y-%m-%d-%H:%M:%S"  >/data/backup/mysql/data/$dateDIR/InnoDBanalyze.log

echo "***************************************" >>/data/backup/mysql/data/$dateDIR/InnoDBanalyze.log

date +"%Y-%m-%d-%H:%M:%S"  >/data/backup/mysql/data/$dateDIR/InnoDBoptimize.log

echo "***************************************" >>/data/backup/mysql/data/$dateDIR/InnoDBoptimize.log

#刷新缓存中的日志

mysqladmin -u$user -p123456 flush-logs

for db in $(mysql -u$user -p123456 -e "show databases" | grep -ve "Database" -ve "mysql" -ve "test" -ve "information_schema")

do

#数据库中每个表的存储引擎

mysql -u$user -p123456 -e "show table status" -D "$db" | sed '1d' | awk '{print $1" "$2}' > table-engine_check.txt

#根据每个表不同的存储引擎,进行修复和优化

while read table engine

do

if [ "$engine" == "MyISAM" ] ; then

mysqlcheck -u$user -p123456 -C -F -f --auto-repair --tables "$db" "$table" >> /data/backup/mysql/data/$dateDIR/MyISAMcheck.log ;

mysql -u$user -p123456  -e "ANALYZE NO_WRITE_TO_BINLOG TABLE $db.$table;" |awk 'END{print $1,$2,$3,$4,$5,$6,$7,$8,$9,$10}'>> /data/backup/mysql/data/$dateDIR/MyISAManalyze.log;

mysql -u$user -p123456  -e "OPTIMIZE NO_WRITE_TO_BINLOG TABLE $db.$table;"|awk 'END{print $1,$2,$3,$4,$5,$6,$7,$8,$9,$10}'>>/data/backup/mysql/data/$dateDIR/MyISAMoptimize.log;

elif [ "$engine" == "InnoDB" ] ; then

mysqlcheck -u$user -p123456 -C -F -f --auto-repair --tables "$db" "$table" >> /data/backup/mysql/data/$dateDIR/InnoDBcheck.log ;

mysql -u$user -p123456  -e "ANALYZE NO_WRITE_TO_BINLOG TABLE $db.$table;" |awk 'END{print $1,$2,$3,$4,$5,$6,$7,$8,$9,$10}'>> /data/backup/mysql/data/$dateDIR/InnoDBanalyze.log;

mysql -u$user -p123456  -e "OPTIMIZE NO_WRITE_TO_BINLOG TABLE $db.$table;"|awk 'END{print $1,$2,$3,$4,$5,$6,$7,$8,$9,$10}'>> /data/backup/mysql/data/$dateDIR/InnoDBoptimize.log;

fi

done < table-engine_check.txt

#针对每个库进行锁表然后备份;将备份后的文件打包压缩到指定目录

mysqldump -u$user -p123456 --default-character-set=utf8 --opt --lock-all-tables ${db}| gzip -9> /data/backup/mysql/data/$dateDIR/${db}_${dateDIR}.sql.gz

done

echo "***************************************" >>/data/backup/mysql/data/$dateDIR/MyISAMcheck.log

date +"%Y-%m-%d-%H:%M:%S"  >>/data/backup/mysql/data/$dateDIR/MyISAMcheck.log

echo "***************************************" >>/data/backup/mysql/data/$dateDIR/MyISAManalyze.log

date +"%Y-%m-%d-%H:%M:%S"  >>/data/backup/mysql/data/$dateDIR/MyISAManalyze.log

echo "***************************************" >>/data/backup/mysql/data/$dateDIR/MyISAMoptimize.log

date +"%Y-%m-%d-%H:%M:%S"  >>/data/backup/mysql/data/$dateDIR/MyISAMoptimize.log

echo "***************************************" >>/data/backup/mysql/data/$dateDIR/InnoDBcheck.log

date +"%Y-%m-%d-%H:%M:%S"  >>/data/backup/mysql/data/$dateDIR/InnoDBcheck.log

echo "***************************************" >>/data/backup/mysql/data/$dateDIR/InnoDBanalyze.log

date +"%Y-%m-%d-%H:%M:%S"  >>/data/backup/mysql/data/$dateDIR/InnoDBanalyze.log

echo "***************************************" >>/data/backup/mysql/data/$dateDIR/InnoDBoptimize.log

date +"%Y-%m-%d-%H:%M:%S"  >>/data/backup/mysql/data/$dateDIR/InnoDBoptimize.log

rm -rf table-engine_check.txt

#删除7天以前的全备份文件和目录

find /data/backup/mysql/data/* -mtime +6 -type d -exec rm -rf {} \;>/dev/null 2>&1

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值