linux下脚本监控mysql主从同步异常时发邮件通知 Linux 发送邮件配置

在MySQL中,同步异常监控通常涉及监控复制的状态。可以通过查询SHOW SLAVE STATUS命令来获取复制的状态信息,并对其进行监控。以下是一个简单的SQL脚本,用于监控MySQL复制状态并输出异常信息:

查mysql slave状态

SHOW SLAVE STATUS\G

如果你需要自动化监控并在发现异常时采取行动,可以编写一个脚本来定期运行这个命令,并根据输出结果判断复制是否正常。

以下是一个简单的Shell脚本示例,用于监控MySQL复制状态并在复制异常时发送邮件报警:

#!/bin/bash
 
# MySQL的用户名、密码、主机和数据库名
USER="your_username"
PASSWORD="your_password"
HOST="your_host"
DBNAME="your_dbname"
 
# 获取复制状态
STATUS=$(mysql -u$USER -p$PASSWORD -h$HOST $DBNAME -e "SHOW SLAVE STATUS\G" 2>&1)
 
# 检查SQL线程和IO线程是否都在运行
if [[ $STATUS == *"Running"* ]]; then
    echo "Replication is running."
else
    echo "Replication error detected:"
    echo "$STATUS"
    
    # 发送邮件报警
    echo "$STATUS" | mail -s "MySQL Replication Error" your_email@example.com
fi

确保你有一个可以发送邮件的邮件服务器配置在你的系统上,并且替换脚本中的your_usernameyour_passwordyour_hostyour_dbname, 和your_email@example.com为实际的值。

这个脚本每次运行时都会检查MySQL复制状态,如果发现异常,它会输出错误信息并发送邮件报警。你可以将其加入到定时任务中(如crontab)以周期性地执行。

Linux 发送邮件配置

安装mailx

mysql检测同步异常脚本

# 安装mailx
yum -y install mailx

在mysql从机 mysqlsynccheck.sh

#!/bin/bash

# MySQL的用户名、密码、主机和数据库名
USER="root"
PASSWORD="root"
HOST="192.168.88.6"
DBNAME="sku"

# 获取复制状态
IO_SQL_STATUS=$(mysql -h$HOST -u$USER -p$PASSWORD -e 'show slave status\G' 2>/dev/null |awk '/Slave_.*_Running:/{print $1$2}')

for i in $IO_SQL_STATUS; do
    THREAD_STATUS_NAME=${i%:*}
    THREAD_STATUS=${i#*:}
    if [ "$THREAD_STATUS" != "Yes" ]; then
        echo "Error: MySQL Master-Slave $THREAD_STATUS_NAME status is $THREAD_STATUS!" |mail -s "Master-Slave Staus" yzzxxx@126.com
    fi
done

给执行权限

chmod +x mysqlsynccheck.sh

加入到crontab中

crontab -e

*/10 * * * *  /root/mysqlsynccheck.sh

Linux 发送邮件配置

 以QQ邮箱为例:帮助系统
登录QQ邮箱 -> 设置 -> 账户 -> 开启服务“POP3/SMTP服务” -> 获取授权码(16个随机字母)

配置mailx服务
# 查看配置信息
cat /etc/mail.rc

# 将下面配置添加到`/etc/mail.rc`文件尾部
echo '
#######################################################
set smtp=smtp.qq.com:587                  # 邮箱服务器地址
set smtp-auth=login                       # 认证方式:采用用户名和密码登录方式
set smtp-auth-user=4988xxxxxx@qq.com       # TODO 账号
set smtp-auth-password=xxx                # TODO 注:这里填写在QQ邮箱`设置` -> `账号` 里面开启`POP3/SMTP服务`生成的`授权码` !!!
set from=4988xxxxxx@qq.com                 # TODO 邮件发送人地址
set ssl-verify=ignore
#######################################################
' >> /etc/mail.rc
发送邮件
# 命令格式:echo '邮件内容' | mail -s '主题' 收件人邮箱(多个邮件空格分隔)
echo 'hello world!' | mail -s '你好' 4988xxx@qq.com yzzxxx@126.com

相关推荐

  1. linux发送邮件实测

    2024-05-11 10:08:07       24 阅读
  2. Spring Boot项目监控异常发送邮件

    2024-05-11 10:08:07       50 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-11 10:08:07       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-11 10:08:07       100 阅读
  3. 在Django里面运行非项目文件

    2024-05-11 10:08:07       82 阅读
  4. Python语言-面向对象

    2024-05-11 10:08:07       91 阅读

热门阅读

  1. Spring Cloud LoadBalancer 4.1.2

    2024-05-11 10:08:07       23 阅读
  2. Acwing2024蓝桥杯并查集

    2024-05-11 10:08:07       150 阅读
  3. 什么是中间件

    2024-05-11 10:08:07       31 阅读
  4. 关于SpringBoot MVC接口超时时间的分析

    2024-05-11 10:08:07       36 阅读
  5. C#爬虫爬取某东商品信息

    2024-05-11 10:08:07       31 阅读
  6. TVM简介

    TVM简介

    2024-05-11 10:08:07      36 阅读
  7. Lua(0)环境搭建与基础代码

    2024-05-11 10:08:07       31 阅读
  8. GraphQL在现代Web应用中的应用与优势

    2024-05-11 10:08:07       29 阅读