博客
关于我
mysql 状态检查,备份,修复
阅读量:800 次
发布时间:2023-02-10

本文共 2659 字,大约阅读时间需要 8 分钟。

MySQL数据库自动化管理脚本

本文将介绍一个用于MySQL数据库自动化管理的Bash脚本,涵盖数据库状态检测、表修复与检查以及数据备份等功能,并支持通过FTP上传备份数据。该脚本适用于生产环境下的数据库管理,能够帮助DBA自动化完成日常任务。

1. 脚本概述

该脚本主要功能包括:

  • 数据库存活状态检测
  • 数据表修复与检查
  • 数据库备份
  • 备份数据的FTP上传

脚本基于Ubuntu 12.04系统,依赖于MySQL、mysqldump以及FTP工具的支持。

2. 数据库状态检测

脚本首先检查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}

3. 数据表修复与检查

在确认数据库已启动的情况下,脚本将检查所有可用数据库中的表状态。对于存在错误的表,脚本将自动触发修复操作,并记录修复日志。

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}

4. 数据库备份

数据库备份功能分为两步:首先清理旧的备份文件,然后执行当前数据库的备份并压缩。

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}

5. 备份数据的FTP上传

脚本支持通过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}

6. 脚本执行方法

脚本可通过以下方式调用:

./mysqlautocheck.sh {check|backup}
  • check:执行数据库状态检测和表修复检查
  • backup:执行数据库备份并上传备份文件
  • *:默认调用数据库状态检测

7. 脚本特点

  • 提供详细日志记录,便于问题追溯
  • 支持自动修复数据库表错误
  • 强化的数据备份机制
  • 支持通过FTP上传备份文件
  • 适用于集群环境下的数据库管理
  • 支持多种数据库状态检测方式

转载地址:http://tfbfk.baihongyu.com/

你可能感兴趣的文章
NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
查看>>
NIFI1.21.0最新版本安装_配置使用HTTP登录_默认是用HTTPS登录的_Https登录需要输入用户名密码_HTTP不需要---大数据之Nifi工作笔记0051
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增加修改实时同步_使用JsonPath及自定义Python脚本_03---大数据之Nifi工作笔记0055
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
NIFI同步MySql数据源数据_到原始库hbase_同时对数据进行实时分析处理_同步到清洗库_实际操作06---大数据之Nifi工作笔记0046
查看>>