使用Springboot Admin搭建服务监控系统并推送钉钉群报警信息

本文介绍了如何使用Springboot Admin搭建服务监控系统,并结合Dingding access_token实现服务异常时向钉钉群发送报警信息。通过Springboot Admin Server注册服务实例,定制报警通知,确保在服务出现异常时能及时接收到报警通知,提高响应效率。

需求背景:系统服务异常触发报警,原来都是邮件报警,邮件报警有其弊端,就是通知响应率和容错率不佳,因为业务邮件和报警邮件在一起,很多人慢慢会忽视邮件的内容,响应率会越来越低,而且邮件的容错率不佳,经常无缘无故“吃”掉你的邮件,使系统异常无法快速实时的到达我们的手中。因此使用即时消息发送报警需求就越来越刚需,钉钉群报警成为了不二之选。

实现技术栈:Springboot Admin、Dingding access_token

实现步骤:

    step1:搭建Springboot Admin Server以及将服务注册到Admin应用实例中

    pom依赖:

<dependency>
    <groupId>de.codecentric</groupId>
    <artifactId>spring-boot-admin-starter-server</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>

     server配置:

     spring.application.name=admin-server

     server.port=8769

     报警代码实现:

            报警通知,继承AbstractStatusChangeNotifier,以及重写他的doNotify方法,instance就是admin推送过来的状态发生异常的实例,具体看AbstractStatusChangeNotifier里的代码会发现,他会先判断哪些实例需要通知,如果enable 设置为了false,就不会通知,而AbstractEventNotifier里面抽象了一个doNotify用于我们具体实现推送消息体内容

public class DingDingNotifier extends AbstractStatusChangeNotifier {
    public DingDingNotifier(InstanceRepository repository) {
        super(repository);
    }
    @Override
    protected Mono<Void> doNotify(InstanceEvent event, Instance instance) {
        String serviceName = instance.getRegistration().getName();
        String serviceUrl = instance.getRegistration().getServiceUrl();
        String status = instance.getStatusInfo().getStatus();
        Map<String, Object> details = instance.getStatusInfo().getDetails();
        StringBuilder str = new StringBuilder();
        str.append("服务宕机测试 : 【" + serviceName + "】");
        str.append("【服务地址】" + serviceUrl);
        str.append("【状态】" + status);
        str.append("【详情】" + JSONObject.toJSONString(details));
        return Mono.fromRunnable(() -> {
            DingDingMessageUtil.sendTextMessage(str.toString());
        });
    }
}

      消息推送实现:

public class DingDingMessageUtil {
    // 从钉钉群获取的
    public static String access_token = "你自己群的access_token";

    public static void sendTextMessage(String msg) {
        try {
            Message message = new Message();
            message.setMsgtype("text");
            message.setText(new MessageInfo(msg));
            URL url = new URL("https://oapi.dingtalk.com/robot/send?access_token=" + access_token);
            // 建立 http 连接
            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
            conn.setDoOutput(true);
            conn.setDoInput(true);
            conn.setUseCaches(false);
            conn.setRequestMethod("POST");
            conn.setRequestProperty("Charset", "UTF-8");
            conn.setRequestProperty("Content-Type", "application/Json; charset=UTF-8");
            conn.connect();
            OutputStream out = conn.getOutputStream();
            String textMessage = JSONObject.toJSONString(message);
            byte[] data = textMessage.getBytes();
            out.write(data);
            out.flush();
            out.close();
            InputStream in = conn.getInputStream();
            byte[] data1 = new byte[in.available()];
            in.read(data1);
            System.out.println(new String(data1));
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

服务注册到admin中

spring.boot.admin.client.url=http://127.0.0.1:8769
spring.application.admin.enabled=true 

好的,完成,多启动几个实例看下页面效果....

应用墙,这UI挺简约,漂亮,大气,上档次,笔者注册了两个应用,各三个实例

正常运营状态下:

服务状态日志变更记录:

step2:接下来模拟下,由于种种原因,服务出现了系统异常,宕机,我们模拟关停调一个服务的实例,看看是否会有报警到达钉钉群消息,先看admin管理

好了,群里面的小伙伴们都收到了,系统报警信息,赶紧瞅瞅什么原因,经过一番排错,原来是xxxxxxx,然后重启服务,ok了

再看admin管理界面

钉钉消息推送:

ok,到此Springboot Admin进行钉钉群消息推送就完成了!!

评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一只小卡拉咪程序猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值