springboot prometheus 整合

XML 复制代码
 <dependency>
            <groupId>io.micrometer</groupId>
            <artifactId>micrometer-registry-prometheus</artifactId>
            <version>1.9.0</version>
        </dependency>

application.yml

XML 复制代码
management:
  endpoints:
    web:
      exposure:
        include: "*"
  metrics:
    tags:
      application: ${spring.application.name}
      instance: ${spring.application.instance_id:${random.value}}
      service: ${spring.application.name}
      service-instance-id: ${spring.application.instance_id:${random.value}}
#      http://localhost:8081/actuator/prometheus

案例

java 复制代码
package com.me.stress1.controller;

import cn.hutool.core.date.TimeInterval;
import com.alibaba.excel.EasyExcel;
import com.alibaba.fastjson.JSONObject;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.me.stress1.domain.IdmsUser;
import com.me.stress1.mapper.IdmsUserMapper;
import com.me.stress1.service.IdmsUserService;
import io.micrometer.core.annotation.Timed;
import io.micrometer.core.instrument.MeterRegistry;
import io.micrometer.core.instrument.Counter;
import org.apache.ibatis.cursor.Cursor;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.UUID;

@RestController
public class IndexController {

    private Logger logger = LoggerFactory.getLogger(IndexController.class);

    @Timed("basic.createID")
    @RequestMapping("/generateId")
    public String createID(){

        System.out.println("fffffldlfdlfld");
        logger.info("createID");
        return UUID.randomUUID().toString();
    }


  
    @Autowired
    private MeterRegistry meterRegistry;
    private Counter counter;


    /**
     *
     *  使用  jmeter  进行压力测试使用
     *   默认 单笔   或2笔数据
     *   测试其相应速度
     *   qps 相关指标
     *
     * @param idmsUser
     * @return
     */
    @PostMapping("/add")
    public JSONObject add(@RequestBody List<IdmsUser> idmsUser){
        /**
         *  统计 调用次数
         */
        counter  = meterRegistry.counter("app_requests_method_count","method","com.me.stress1.controller.IndexController.add");

        /**
         * 
         *  业务逻辑
         */
        JSONObject object = new JSONObject();
        object.put("code",200);
        object.put("msg","ok");
        object.put("data",idmsUser);
        counter.increment();
        return object;
    }
   
}

把项目的端口地址配置到 prometheus 配置文件中去 即可实现微服务监控

相关推荐
zfoo-framework14 分钟前
帧同步和状态同步
java
charlotte1024102417 分钟前
高并发:关于在等待学校教务系统选课时的碎碎念
java·运维·网络
亓才孓22 分钟前
[JDBC]PreparedStatement替代Statement
java·数据库
_F_y44 分钟前
C++重点知识总结
java·jvm·c++
打工的小王1 小时前
Spring Boot(三)Spring Boot整合SpringMVC
java·spring boot·后端
毕设源码-赖学姐1 小时前
【开题答辩全过程】以 高校体育场馆管理系统为例,包含答辩的问题和答案
java·spring boot
我真会写代码1 小时前
SSM(指南一)---Maven项目管理从入门到精通|高质量实操指南
java·spring·tomcat·maven·ssm
vx_Biye_Design1 小时前
【关注可免费领取源码】房屋出租系统的设计与实现--毕设附源码40805
java·spring boot·spring·spring cloud·servlet·eclipse·课程设计
DN金猿1 小时前
接口路径正确,请求接口却提示404
java·tomcat
翱翔-蓝天1 小时前
为什么“看起来很规范”的后端项目反而臃肿且性能下降
spring boot