Springboot自定义Prometheus采集指标

添加依赖

复制代码
<!--增加Prometheus依赖-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
    <groupId>io.micrometer</groupId>
    <artifactId>micrometer-registry-prometheus</artifactId>
</dependency>

项目配置

配置application.yml文件

复制代码
spring:
    application:
        name: my-metrics

server:
    port: 8080
    tomcat:
      mbeanregistry:
          enabled: true #启用Tomcat MBean注册表,以便于通过JMX进行监控和管理

management:
    endpoints:
        web:
            exposure:
                include: "*" #将所有Actuator端点暴露
    prometheus:
        metrics:
            export:
                enabled: true #启用Prometheus指标导出
    metrics:
        tags:
            application: ${spring.application.name}

自定义指标

复制代码
import io.micrometer.core.instrument.Gauge;
import io.micrometer.core.instrument.MeterRegistry;
import io.micrometer.core.instrument.Tags;
import jakarta.servlet.*;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.function.Supplier;

/**
 * @Description 使用过滤器添加自定义指标
 **/
@Component
public class MyMetricsFilter implements Filter {

    @Autowired
    private MeterRegistry registry;

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        //自定义指标方法
        addMetrics();
        filterChain.doFilter(servletRequest, servletResponse);
    }

    /**
     * 添加自定义指标,根据业务场景自行方法逻辑
     */
    public void addMetrics() {
        List<String> sysNames = new ArrayList<>();
        sysNames.add("sys1");
        sysNames.add("sys2");

        sysNames.forEach(sysName -> {
// 构建Gauge指标并注册
            Gauge.builder("my.metrics.monitor", getValue(sysName)) // getValue(sysName)返回一个Supplier<Number>对象, 对象值为匿名函数, 匿名函数会在创建指标时调用,返回自定义指标的值
                    .tags(Tags.of("service", sysName)) // 指标标签
                    .description("my metrics monitor") // 指标描述
                    .register(registry); // 注册到MeterRegistry
        });
    }

    public Supplier<Number> getValue(String sysName) {
        return () -> {
            // 在这里使用 sysName 参数, 编写自定义指标的逻辑
            System.out.println("System name: " + sysName);
            return sysName.hashCode();
        };
    }
}

获取自定义指标

启动项目,访问http://localhost:8080/actuator/prometheus,即可获取自定义指标

相关推荐
有什么东东6 分钟前
山东大学软件学院创新项目实训开发日志(20)之中医知识问答自动生成对话标题bug修改
java·vue·bug·springboot
我爱布朗熊4 小时前
4.RabbitMQ - 延迟消息
rabbitmq·springboot
mask哥10 小时前
详解springcloudalibaba采用prometheus+grafana实现服务监控
java·nacos·springboot·grafana·prometheus·springcloud·微服务监控
幽络源小助理17 小时前
SpringBoot民宿管理系统开发实现
java·spring boot·springboot·民宿系统
古渡蓝按1 天前
微信支付功能的设计实现与关键实践(UniApp+Java)全代码
springboot
Nick_zcy2 天前
协同推荐算法实现的智能商品推荐系统 - [基于springboot +vue]
算法·springboot·推荐算法
洛阳泰山2 天前
LangChain4j 搭配 Kotlin:以协程、流式交互赋能语言模型开发
java·ai·语言模型·kotlin·交互·springboot·langchain4j
飞天小牛肉4 天前
拼多多面经,暑期实习Java一面
java·spring·springboot·秋招·校招
橘猫云计算机设计4 天前
django基于爬虫的网络新闻分析系统的设计与实现(源码+lw+部署文档+讲解),源码可白嫖!
后端·爬虫·python·django·毕业设计·springboot
南客先生5 天前
海量聊天数据处理:基于Spring Boot与SharingJDBC的分库分表策略及ClickHouse冷热数据分离
mysql·clickhouse·springboot·分库分表·大数据处理·sharingjdbc