webhook接收告警写入mysql

package main

import (
	"database/sql"
	"encoding/json"
	"fmt"
	"io"
	"math/rand"
	"net/http"
	_ "os"
	"strconv"
	"strings"
	"time"

	"github.com/gin-gonic/gin"
	_ "github.com/go-sql-driver/mysql"
)

type Alert struct {
	Receiver string   `json:"receiver"`
	Status   string   `json:"status"`
	Alerts   []Alerts `json:"alerts"`
}

type Alerts struct {
	Status       string      `json:"status"`
	Labels       Labels      `json:"labels"`
	Annotations  Annotations `json:"annotations"`
	StartsAt     string      `json:"startsAt"`
	EndsAt       string      `json:"endsAt"`
	GeneratorURL string      `json:"generatorURL"`
	Fingerprint  string      `json:"fingerprint"`
}

type Labels struct {
	Alertname    string `json:"name"`
	Device       string `json:"device"`
	FSType       string `json:"fstype"`
	Instance     string `json:"instance"`
	Job          string `json:"job"`
	MountPoint   string `json:"mountpoint"`
	Severity     string `json:"severity"`
	System       string `json:"system"`
	Yunyingshang string `json:"yunyingshang"`
	Judian       string `json:"judian"`
}

type Annotations struct {
	Description string `json:"description"`
	Summary     string `json:"summary"`
}

type Alarm struct {
	IP      string
	System  string
	ISP     string
	Desc    string
	Judian  string
	Summary string
}

func NewAlarm(value Alerts) Alarm {
	isp := value.Labels.Yunyingshang
	if len(isp) == 0 {
		isp = "wa"
	}
	ip := strings.Split(value.Labels.Instance, ":")[0]
	summary := value.Annotations.Summary
	// desc := ip + summary
	system := value.Labels.System
	if len(system) == 0 {
		system = "wa"
	}
	judian := value.Labels.Judian
	if len(judian) == 0 {
		judian = "wa"
	}
	return Alarm{
		IP:     ip,
		System: system,
		ISP:    isp,
		// Desc:   desc,
		Judian:  judian,
		Summary: summary,
	}
}

var onlyalartmID string

func generateAlarmID() (alarmID string) {
	prefix := "wamaster"
	dateStr := time.Now().Format("200601021504")
	rand.Seed(time.Now().UnixNano())
	randStr := strconv.Itoa(rand.Intn(9000) + 1000)
	alarmID = prefix + dateStr + randStr
	return
}

func InsertData(alarm Alarm) error {
	// 这里插入数据

	return nil
}

func insertAlertToDB(db *sql.DB, alert Alert) error {
	// 在这里编写插入告警数据的SQL语句,例如:
	query := `INSERT INTO hookdata (ip, status, alertid, system, isp, judian, summary, tuitime) VALUES (?, ?, ?, ?, ?, ?, ?, ?)`
	stmt, err := db.Prepare(query)
	if err != nil {
		return err
	}
	defer stmt.Close()

	for _, value := range alert.Alerts {
		onlyalartmID = generateAlarmID()
		status := 0
		alarm := NewAlarm(value)
		_ = InsertData(alarm)
		// ipmiaoshu = alarm.IP + alarm.Desc
		currentTime := time.Now().Format("2006-01-02 15:04:05") // 获取当前时间并格式化为字符串
		_, err = stmt.Exec(alarm.IP, status, onlyalartmID, alarm.System, alarm.ISP, alarm.Judian, alarm.Summary, currentTime)
		if err != nil {
			return err
		}
	}
	return nil
}

func main() {
	fmt.Println(generateAlarmID())
	// os.Exit(0)
	r := gin.Default()
	// 连接到MySQL数据库
	db, err := sql.Open("mysql", "root:111111@tcp(localhost:3306)/alert")
	if err != nil {
		panic(err)
	}
	defer db.Close()

	r.POST("/webhook", func(c *gin.Context) {
		body, err := io.ReadAll(c.Request.Body)
		if err != nil {
			c.JSON(http.StatusBadRequest, gin.H{"error": "无法读取请求体"})
			return
		}

		var alert Alert
		err = json.Unmarshal(body, &alert)
		if err != nil {
			c.JSON(http.StatusBadRequest, gin.H{"error": "无法解析告警信息"})
			return
		}
		//打印出告警信息进行调试
		for _, value := range alert.Alerts {
			onlyalartmID = generateAlarmID()
			status := 0
			alarm := NewAlarm(value)
			_ = InsertData(alarm)
			// ipmiaoshu = alarm.IP + alarm.Desc
			currentTime := time.Now().Format("2006-01-02 15:04:05") // 获取当前时间并格式化为字符串
			fmt.Printf("ip: %s\n status: %v\n alertid: %s\n system: %s\n isp: %s\n judian: %s\n summary: %s\n tuitime: %T\n", alarm.IP, status, onlyalartmID, alarm.System, alarm.ISP, alarm.Judian, alarm.Summary, currentTime)
		}

		// 将告警信息插入到数据库
		err = insertAlertToDB(db, alert)
		if err != nil {
			fmt.Println(err)
			c.JSON(http.StatusInternalServerError, gin.H{"error": "无法将告警信息插入到数据库"})
			return
		}
		c.JSON(http.StatusOK, gin.H{"message": "告警已接收并存储到数据库"})
	})

	r.Run(":8080") // 监听8080端口
}

  • 8
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Zabbix的Webhook告警是一种通过Webhook机制发送告警通知的方式。在Zabbix中,我们可以使用JavaScript来编写自定义的Webhook媒介类型,以实现发送钉钉或企业微信等报警通知。\[2\]\[3\] 为了方便使用JavaScript的预处理和使用Webhook的媒介类型,Zabbix官方特意封装了一些对象供我们使用。其中,写入Zabbix日志的对象可以使用Log(loglevel, message)方法将日志按照指定的日志级别写入Zabbix日志文件,日志级别可以参考Zabbix的配置文件。这样可以方便我们在调试过程中查找错误原因。\[1\]\[2\] 在Zabbix 5.0中,对于告警(报警媒介)进行了扩展和优化,直接支持Webhook类型的报警媒介。因此,我们可以通过JavaScript语言编写脚本来实现在企业微信发送告警信息。这样的告警脚本具有通用性和灵活性,得到了Zabbix的原生支持。\[3\] 如果你想使用Zabbix的Webhook告警功能,首先需要注册企业微信机器人。具体的注册步骤可以参考相关文档或官方指南。一旦注册完成,你就可以在Zabbix中配置Webhook媒介类型,并编写相应的JavaScript脚本来实现告警通知的发送。\[3\] #### 引用[.reference_title] - *1* *2* [Zabbix使用JavaScript配置webhook发送告警通知](https://blog.csdn.net/wanger5354/article/details/118725564)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Zabbix 5.0 企业微信 WebHook 实现故障文本告警](https://blog.csdn.net/weixin_53971298/article/details/113619936)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值