温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

年轻人的第一个go程序:监控数据库字段 报警

发布时间:2020-07-16 14:47:17 来源:网络 阅读:664 作者:295631788 栏目:编程语言

监控数据库字段 钉钉报警

package main

import (
    "bytes"
    "encoding/json"
    "fmt"
    _ "github.com/go-sql-driver/mysql"
    "github.com/go-xorm/xorm"
    "io/ioutil"
    "net/http"
    "time"
)

var engine *xorm.Engine

const webhook_url = "https://oapi.dingtalk.com/robot/send?access_token=xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"

func dingtoinfo(s string) bool {
    content, data := make(map[string]string), make(map[string]interface{})
    content["content"] = s
    data["msgtype"] = "text"
    data["text"] = content
    b, _ := json.Marshal(data)

    resp, err := http.Post(webhook_url,
        "application/json",
        bytes.NewBuffer(b))
    if err != nil {
        fmt.Println(err)
    }
    defer resp.Body.Close()
    body, _ := ioutil.ReadAll(resp.Body)
    fmt.Println(string(body))
    return true
}
func recoverName() {
    if r := recover(); r != nil {
        res := fmt.Sprintf("%s %s", "监控程序 报错:", r)
        dingtoinfo(res)
    }
}

func main() {
    defer recoverName()
    var err error
    engine, err = xorm.NewEngine("mysql", "root:xxxxxxxxxxxxxxx@tcp(127.0.0.1:3306)/new?charset=utf8")

    if err != nil {
        panic(err.Error())
    }
    gsql := " select up_time from token where type = 0 ;"
    gres, gerr := engine.Query(gsql)

    if gerr != nil {
        panic(gerr.Error())
    }
    var data string
    for _, v := range gres {
        data = string(v["up_time"])
    }
    loc, _ := time.LoadLocation("Asia/Shanghai")
    nowTime := time.Now().In(loc)

    tm, _ := time.Parse("2006-01-02 03:04:05", data)
    ntm := tm.In(loc)
    subM := nowTime.Sub(ntm)
    fmt.Println("token更新时间 与 系统时间 相差",subM)
    subtract := int(subM.Minutes())
    if subtract > 20 {
        dingtoinfo("异常, 请及时登录查看 !!!")
    }
}
向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI