pinpoint实现告警推送至钉钉和微信群

前言

在前面的文章中,我们学习了如何通过java实现将消息发送到钉钉、和将消息发送到微信群聊。

基于上述基础,我们今天来接入pinpoint的告警,发送到钉钉群。

实操前准备

开始之前,推荐阅读一下,官方的告警说明文档。

阅读官方文档后,我们实际的来操作一遍。

按照官方说明,首先需要创建对应的用户组和用户,但是我们这里打开有异常:

通过后台,pinpoint-web的日志可以发现,这是由于没有配置mysql表的原因。

步骤1-配置mysql表

首先,我们创建一个名为pinpoint的数据库。

然后,导入官方的脚本,配置好需要的表。

导入的所有表显示如下:

导入15张数据表后,我们需要修改pinpoint-web的jdbc.properties配置文件。

配置好正确的数据库和账号密码后,重启pinpoint-web。

步骤2-界面配置用户组和用户

首先配置一个用户组,然后在这个组下面新建一个用户。

用户这里输入id、用户名、手机号、邮箱等信息添加即可。

步骤3-添加应用的告警规则

配置完用户后,接着我们配置对应应用的告警规则

这里我针对testboot这个服务,配置了一个慢 请求告警,当慢请求大于5个时,就会触发。

这里的type选项指定告警的方式,可以是短信、邮件,或者两者。

然后包含具体的告警指标,这里我单纯选择的是Slow count,慢请求个数。

具体每个指标的含义,考虑后续再出一篇文章来作详细解释。

这篇主要以实现告警功能为目的,就不再深入了。

至此,告警规则就配置好了。

步骤4-改造源码思路分析

冷静分析

pinpoint 采用Spring Batch框架来运行job,其中
一个Job有多个Step,每个step又包含一系列规定动作(read,process,write)。

界面上所有的可配置指标都是通过Checker计算出来的,我们的Slow Count的也不例外。

AlarmMessageSender是我们需要关注的告警接口,它有一个空的实现类,EmptyMessageSender。

本来打算直接在这个类里面写代码的,但转念一想,还是算了,因为他没有被spring管理,是直接new出来的,我们后面可能需要依赖spring的一些bean,避免用着不方便,所以还是自己写一个类来实现把。

默认情况下,我们都只是使用不带任何参数的@Autowired。
设置required参数为false,表示忽略当前要注入的bean,如果有直接注入,没有跳过,不会报错。

步骤5-进行源码改造

新建一个类,实现告警接口,源码我上传到了github,需要的小伙伴,公众号回复钉钉,即可获取。

写完代码后,我们上传编译后的class文件到WEB-INF/classes/com/navercorp/pinpoint/web/alarm目录下:

由于我使用了一个内部类,所以一共有两个class文件。

改一下文件权限

chmod 777 ./DingTalkAndWechatMessageSender.class

chmod 777 ./DingTalkAndWechatMessageSender$DingResponse.class

在/WEB-INF/classes/pinpoint-web.properties配置中新增
web.ding.talk.url属性配置,这个属性就是钉钉的webhok地址。

当然你也可以写具体的微服务地址,来进行更多的逻辑处理,这里为了让大家开箱即用,我将消息直接推送给钉钉。

有了推送的url后,我们在applicationContext-web.xml中添加一个bean配置。

    <bean id="dingTalkAndWechatMessageSender" class="com.navercorp.pinpoint.web.alarm.DingTalkAndWechatMessageSender" >
        <property name="dingTalkUrl" value="#{pinpointWebProps['web.ding.talk.url'] ?: ''}"/>
    </bean>

步骤6-测试验证

查看是否赋值成功:

调用业务接口,我伪造了一个慢请求接口

验证日志:

验证钉钉消息:

总结

如上,就是将pinpoint告警接入钉钉群的全部过程,若有任何疑问,欢迎来交流讨论。
通过这篇文章,来复测以下,是否掌握了以下知识呢:
1、如何发送消息接入钉钉群聊。

2、如何编译class增量发布。(虽然并不是很推荐这种方式,但是为了提高效率所以这样用了)

3、如何实现pinpoint的告警接口。

4、pinpoint告警类读取配置文件方式。

推送告警到微信群,就不再文章讲述了,有需求的小伙伴可以自行研究实现。希望大家多多总结,提高自己。

欢迎来公众号【侠梦的开发笔记】,回复干货,领取精选学习视频一份

原文地址:https://www.cnblogs.com/hyq0823/p/12202459.html

时间: 2024-10-10 04:36:33

pinpoint实现告警推送至钉钉和微信群的相关文章

Python之钉钉机器人推送天气预报

通过Python脚本结合钉钉机器人,定时向钉钉群推送天气预报 #!/usr/bin/python # -*- coding: utf-8 -*- # Author: [email protected] # My blog http://m51cto.51cto.blog.com import requests import re import urllib2 import json import sys import os headers = {'Content-Type': 'applicat

【转】[钉钉通知系列]Jenkins发布后自动通知

转载请注明出处:https://www.cnblogs.com/jianxuanbing/p/7211006.html 阅读目录 一.前言 二.使用钉钉推送的优势 三.配置 一.前言 最近使用Jenkins进行自动化部署,但是发布署后,并没有相应的通知,虽然有邮件发送通知,但是发现邮件会受限于大家接受的设置,导致不能及时看到相关的发布内容.由于之前有用Gitlab推送消息到钉钉的方式,因此考虑Jenkins是否能通知到钉钉的实现方式. 二.使用钉钉推送的优势 实时提醒项目参与人员信息的更新 便于

持续集成之 Jenkins 钉钉通知(八)

一.前言 最近使用 Jenkins 进行自动化部署,但是发布署后,并没有相应的通知,虽然有邮件发送通知,但是发现邮件会受限于大家接受的设置,导致不能及时看到相关的发布内容.由于之前有用 Gitlab 推送消息到钉钉的方式,因此考虑 Jenkins是否能通知到钉钉的实现方式. 二.使用钉钉推送的优势 实时提醒项目参与人员信息的更新. 便于查看. 三.钉钉的配置 1. 成为钉钉群主 进入某个群->点击机器人图标. 注意:如果你不是群主,且群主开启了仅群主可管理,那么你将无法创建机器人. 2.选择自定

Jenkins发布后自动通知【钉钉】

阅读目录 一.前言 二.使用钉钉推送的优势 三.配置 一.前言 最近使用Jenkins进行自动化部署,但是发布署后,并没有相应的通知,虽然有邮件发送通知,但是发现邮件会受限于大家接受的设置,导致不能及时看到相关的发布内容.由于之前有用Gitlab推送消息到钉钉的方式,因此考虑Jenkins是否能通知到钉钉的实现方式. 二.使用钉钉推送的优势 实时提醒项目参与人员信息的更新 便于查看 三.配置 3.1 钉钉的配置 3.1.1 进入钉钉群 进入某个群->点击机器人图标注意:如果你不是群主,且群主开启

微信小程序开发:设置消息推送

开发设置中,启用并设置消息推送配置后,用户发给小程序的消息以及开发者需要的事件推送,都将被微信转发至该服务器地址中. 不过照着说明去操作,即使按照最简单的明文方式去设置,还是提示Token验证失败.仔细研究说明,其实服务器验证过程很简单,用Get发来一个连接,然后在自己的页面中去检验,不想做也可以先不做,直接返回echostr即可.关键在,怎么返回,开始我还以为必须要按照xml或者json返回,试了半天,其实很简单,清空所有其他输出,直接返回echostr即可. Response.Clear()

android app 集成 信鸽推送

推送其实挺中意小米推送的,并经用户群占比还是比较大的,奈何拗不过php后端哥们的选型,就只好用信鸽推送了,期间接入过程中也是遇到不少问题,所以记录下来,以后如果还是用信鸽推送的话,估计看看以前的博客,也能少踩点坑. 因为最新版本是2.43,所以按照2.43的引入为准 1,导入jar包和so文件: 文件夹为信鸽推送必须的so文件: 2,针对so文件,gradle文件进行配置,生成第一张图里面的native_libs2的jar文件: 3,AndroidManifest.xml文件的配置,这个基本按照

互联网产品消息推送设计策略(转)

在移动互联时代,消息推送越来越受到各个APP的重视,本文就以互金产品为例阐述消息推送的几个类别以及应用的场景方式.运营策略,希望对你有益. 在之前一文中,笔者概括性的介绍了通知功能是互金理财平台的一个基础但重要的功能.消息推送能将个人账户相关.平台相关内容送达终端用户,是为互联网产品一个重要的功能.在移动互联网时代,移动客户端出现寡头效应,消息推送愈发重要,而在互金产品中尤甚. 因此本文将开始重点阐述互金产品消息推送的类别.场景.方式和前后端推送设计策略以及运营策略. 1 定义 本文所指的"互金

HTML5服务器端推送事件 解决PHP微信墙推送问题

问题描述 以前的文章中<PHP微信墙制作,开源>已经用PHP搭建了一个微信墙获取信息的服务器,然后我就在想推送技术应该怎么解决,上一篇已经用了.NET 的signalr做了一个微信墙,PHP一直没什么好思路,本来想用websocket,但自己写socket要解析websocket协议,PHP有一个比较好的实现是workerman,github地址请戳这里,但是都不是很中意,昨天给自己做官网的时候,看了一下MDN,浏览发现了这个东西"使用服务器发送事件",突然就有了思路,今天

docker高级应用之镜像打包与节点推送

目前我这里使用docker做caas平台,主要是解决: 1.运维沙箱环境测试: 2.研发半自动化代码部署与回滚: 3.集群化应用与auto scale. 目前这3点都实现,但在第2点与第3点联系的时候有个问题.在第2里,研发测试成功的代码会被打包为一个images,放入私有库,然后第3部集群更新的时候,会选择这个成功版本的镜像,但在更新中,由于每个节点都需要从私有库里获取镜像,这样节点越多更新越慢,所以为了解决这个问题,我这里在第二步研发打包image之后,会进行一下所有节点推送,这样在进行集群