本文共 2659 字,大约阅读时间需要 8 分钟。
本文将介绍一个用于MySQL数据库自动化管理的Bash脚本,涵盖数据库状态检测、表修复与检查以及数据备份等功能,并支持通过FTP上传备份数据。该脚本适用于生产环境下的数据库管理,能够帮助DBA自动化完成日常任务。
该脚本主要功能包括:
脚本基于Ubuntu 12.04系统,依赖于MySQL、mysqldump以及FTP工具的支持。
脚本首先检查MySQL服务是否正常运行。若发现MySQL未运行,脚本将记录日志并尝试启动服务。若多次启动失败,脚本将触发报警并停止执行。
mysqllive() { while [[ `pidof mysqld` == "" ]]; do echo "$(date +%Y%m%d%H%M),MYSQL IS DOWN" >> /var/log/mysqlstat.log service mysql start num=0 if [ $num -gt 11 ]; then echo "$(date +%Y%m%d%H%M),MYSQL NO UP" >> /var/log/mysqlstat.log exit 1 fi sleep 10 done}
在确认数据库已启动的情况下,脚本将检查所有可用数据库中的表状态。对于存在错误的表,脚本将自动触发修复操作,并记录修复日志。
mysqlsamchk() { mysqllive if [[ `which mysqlcheck` == "" ]]; then for i in ${mysqldata[@]}; do mytables=$(mysql -h$mysqlhost -u$username -p$passwd -e "use $i;show tables;" | grep -vE "Tables_in_") for j in ${mytables[@]}; do table_status=$(mysql -h$mysqlhost -u$username -p$passwd -e "check table $i.$j" | awk 'BEGIN{IFS='\t'}{print $3}' | grep "error") if [[ ! "$table_status" == "" ]]; then mysql -h$mysqlhost -u$username -p$passwd -e "repair table $i.$j" > /var/log/mysqlstat.log echo "$(date +%Y%m%d%H%M),$i.$j be repair" >> /var/log/mysqlstat.log fi done done else mysqlcheck --all-databases --auto-repair -u$username -p$passwd | awk '!/OK/ {printf "datetime,%s\n",$1}' | sed "s/datetime/$(date +%Y%m%d%H%M)/g" > /var/log/mysqlstat.log fi}
数据库备份功能分为两步:首先清理旧的备份文件,然后执行当前数据库的备份并压缩。
mysqlbackup() { mysqllive [ ! -d $backuppath ] && mkdir $backuppath for i in ${mysqldata[@]}; do find $backuppath -name $i*.zip -type f -mtime +7 -exec rm {} ; mysqldump --opt -h$mysqlhost -u$username -p$passwd $i | gzip > $backuppath/$i$(date +%Y%m%d%H%M).zip done}
脚本支持通过FTP上传备份数据到远程服务器。用户可通过配置文件设置FTP服务信息,脚本将自动调用Python脚本完成文件上传。
dataftp() { ftphost='' ftpusr='' ftpd='' ftpcmd='' tmp="/tmp/$(date +%Y%m%d)" [ ! -f $tmp ] && touch $tmp for j in $(ls $backuppath/*$(date +%Y%m%d)*); do cd $backuppath md5sum `basename $j` >> $tmp python $ftpcmd -t upload -H $ftphost -u $ftpusr -p $ftpd -l $j -r "/${j##*/}" done python $ftpcmd -t upload -H $ftphost -u $ftpusr -p $ftpd -l $tmp -r $(date +%Y%m%d) rm $tmp}
脚本可通过以下方式调用:
./mysqlautocheck.sh {check|backup}
check
:执行数据库状态检测和表修复检查backup
:执行数据库备份并上传备份文件*
:默认调用数据库状态检测转载地址:http://tfbfk.baihongyu.com/