zoukankan      html  css  js  c++  java
  • mysubmail 短信报警

    https://www.mysubmail.com/chs/documents/developer/YPWD84   文本文档
     
     官网:www.mysubmail.com 

    操作流程:
    快速接入短信 API接口并测试发送操作指引
    仅需6步 即可完成 API短信发送

      1. SDK开发包下载链接与代码示例
    https://www.mysubmail.com/chs/documents/developer/index 


    2. 短信验证码 API介绍文档
    https://www.mysubmail.com/chs/documents/developer/t2f1J2 


    3. 一分钟实名认证
    https://www.mysubmail.com/chs/account/settings#/agreement 


    4. 创建短信项目模板
    https://www.mysubmail.com/chs/sms/templates 


    5. 创建短信项目发送 AppID
    https://www.mysubmail.com/chs/sms/apps 


    6. 提交并发送API测试短信
     
     
     
    脚本如下:
     
     #!/bin/bash

    Mail_User="yinhuanyi_cn@163.com"
    Tel_User="18670236750"
    User=root
    Password=123456
    Host=localhost
    MySQL_Login="mysql -u$User -h$Host -p$Password"


    # 检查数据库的复制情况
    Check_Repl(){

            # 将 yes yes 0 赋值 给一个arguments数组
            arguments=(`$MySQL_Login -e "show slave statusG" | awk -F: '/_Running|_Behind_/{print $NF}'`) 

            # 判断下argument数组中的最后一个元素是否是null,如果是Null这么给其赋值一个延时值
            expr ${arguments[2]} + 1 &> /dev/null
            retval=$?

            if [ $retval -ne 0 ];then
                arguments[2]=500
            fi

            if [ "${arguments[0]}" == "Yes" -a "${arguments[1]}" == "Yes" -a "${arguments[2]}" -lt 100 ];then

                    # 数据库复制正常
                    echo " MySQL repl is healthy "
                    return 0

            else

                    # 如果复制有错误,延时超过阈值,
                    echo "MySQL repl is wrong"
                    echo "Trying to repair it"

                    # set global sql_slave_skip_counter=1 是跳过一个event事物
                    # 这种解决方式应用于:当允许主从数据可以微小不一致的情况下
                    # 如果必须主从数据库一致,那么应该使用备份还原的方式,将数据恢复再同步(切记)
                    $MySQL_Login -e "stop slave; set global sql_slave_skip_counter=1; start slave;" && echo "slave restart ok" || echo "slave restart failed"
     
            fi

            return 1

    }

    # 发送邮件报警
    Send_Mail(){

            # 设置主题
            Subject="mysql  repl is wrong"

            # 发送邮件
            echo "$1 MySQL repl is wrong, Deal with it as quickly as possible " | mail -s "$Subject"  "$Mail_User"

    }

    # 发送短信报警(这里试用submail给大家演示发送短信报警, 微信报警自行搞定)
    Send_DX(){

            # 拿到报警时间
            TIME=$1
            # 这是appid
            APPID=17468
            # 这是指纹识别码
            SIGNATURE=a930ebc11c16ca1ee99b24548cda1273

            # 发送短信网关
            HTTP=https://api.mysubmail.com/message/send.json 


            # 发送短信
            # curl -d "appid=17468&to=18670236750&content=【MySQL】MySQL主从复制出现问题,请立即处理&signature=a930ebc11c16ca1ee99b24548cda1273" https://api.mysubmail.com/message/send.json 

    }

    # 发送消息
    Send_Message(){

            # 拿到当前系统时间
            Time=`date "+%F %T"`

            # 发送短信
            Send_DX $Time

            # 发送邮件
            Send_Mail $Time

    }


    # 主函数入口
    Main(){

            while true; do

                    # 先检查数据库复制是否有问题
                    Check_Repl
                    retval=$?

                    if [ $retval -eq 0 ];then

                            echo "MySQL repl  is healthy"

                    else

                            # 如果有问题发送 
                            Send_Message 

                    fi

                    # 让监控脚本30秒执行一次
                    sleep 30

            done

    }

    # 所有的任务从这里开始执行
    Main
     
     
     
    在linux中操作
     
     curl -d 'appid=17490&to=18720170604&content=【abc】abc&signature=4d8efbb6b2343a69b7820621d11ded8b' 
  • 相关阅读:
    Spring实现声明式事务
    Spring整合MyBatis
    Spring AOP
    代理模式
    Bean的作用域
    Spring的配置
    HQL题目记录以及解题思路--持续更新
    数仓学习之路一:数仓理论
    DBeaver连接Hive遇到的坑
    MySQL常见面试题
  • 原文地址:https://www.cnblogs.com/liu1026/p/7844249.html
Copyright © 2011-2022 走看看