sprinngboot+micrometer+prometheus项目监控

1.pom需要添加的依赖

2.application.yml的配置内容

#监控配置

management:

  security:

# 仅限于 开发环境可对security进行关闭。

    enabled: false

  metrics:

    export:

      prometheus:

        enabled: true

        step: 1m

        descriptions: true

  web:

    server:

      auto-time-requests: true

  endpoints:

    prometheus:

      id: springmetrics

    web:

      exposure:

        include: health,info,env,prometheus,metrics,httptrace,threaddump,heapdump,springmetrics

3.代码

package com.sitech.vehicle.job;

import com.alibaba.fastjson.JSON;

import com.alibaba.fastjson.JSONObject;

import com.sitech.utils.http.HttpRequest;

import com.sitech.utils.http.HttpResponse;

import com.sitech.vehicle.config.Constant;

import com.sitech.vehicle.operator.dto.CommonRequestDTO;

import com.sitech.vehicle.operator.dto.OperatorCmdDTO;

import com.sitech.vehicle.tsp.dto.cmd.CmdDTO;

import com.sitech.vehicle.utils.AESUtils;

import com.sitech.vehicle.utils.SignatureUtils;

import io.micrometer.core.instrument.*;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import org.springframework.http.HttpHeaders;

import org.springframework.http.HttpStatus;

import org.springframework.http.MediaType;

import org.springframework.scheduling.annotation.Scheduled;

import org.springframework.stereotype.Component;

import java.util.*;

import java.util.concurrent.atomic.AtomicInteger;

@Component

public class ControlCmdJob {

    private static Logger logger = LoggerFactory.getLogger(ControlCmdJob.class);

List<Tag> init(){

        ArrayList<Tag> list = new ArrayList(){};

        list.add(new ImmutableTag("service", "demo"));

        return list;

    }

    AtomicInteger atomicInteger = new AtomicInteger(0);

    AtomicInteger passCases =  Metrics.gauge("vehicle.cmd.timeout", init(), atomicInteger);

    private String CloudApiUrl = "https://v2n-sv.sitechdev.com";

    private String CloudApiUrl2 = "https://cloud-api.sitechdev.com";

    private String urlCaller4Get(String url) {

        HttpResponse response = HttpRequest.get(url)

                .execute();

        return response.body();

    }

    private String getCmdParam(String vin) throws Exception {

        Long operatorId = 200353L;

        String sercret = "7b2566668cce3bffc794816548383d03";

        CommonRequestDTO commonRequestDTO = new CommonRequestDTO();

        commonRequestDTO.setOperatorID(operatorId);

        commonRequestDTO.setTimestamp(new Date().getTime());

        OperatorCmdDTO operatorCmdDTO = new OperatorCmdDTO();

        operatorCmdDTO.setVin(vin);

        CmdDTO cmdDTO = new CmdDTO();

        cmdDTO.setCmdName("open_search_lighting");

        operatorCmdDTO.setCmdDTO(cmdDTO);

        String content = JSONObject.toJSONString(operatorCmdDTO);

        String encontent = AESUtils.Encrypt(content, sercret);

        commonRequestDTO.setData(encontent);

        Map<String, String> map = new HashMap<String, String>();

        map.put("operatorID", commonRequestDTO.getOperatorID() + "");

        map.put("data", commonRequestDTO.getData());

        map.put("timestamp", commonRequestDTO.getTimestamp() + "");

        System.out.println("业务参数:" + content);

        System.out.println("加密后: " + encontent);

        try {

            String signature = SignatureUtils.generate(map, sercret);

            System.out.println("签名 : " + signature);

            commonRequestDTO.setSign(signature);

        } catch (Exception e) {

            e.printStackTrace();

        }

        System.out.println(JSONObject.toJSONString(commonRequestDTO));

        return JSONObject.toJSONString(commonRequestDTO);

    }

    @Scheduled(cron = "0/40 * * * * ? ") // 间隔40秒执行,查询车控次数,入库

    public void health() {

        String url = CloudApiUrl + Constant.URL;

        String vin = "XTEVE000000D01001";

        //TODO 调用车控接口,监控车控服务是否异常

        try {

            String responseA=urlCaller4Get(CloudApiUrl2+"/sitechid/authcenter/v2/security/operator-token-build/200353?appKey=7b2566668cce3bffc794816548383d03");

            String token= JSON.parseObject(responseA).getJSONObject("data").getString("operatorToken");

            String operatorId="Operator"+" "+token;

            HttpResponse response = null;

            System.out.println("----"+getCmdParam(vin));

            response = HttpRequest.post(url)

                    .header(HttpHeaders.CONTENT_TYPE, MediaType.APPLICATION_JSON_VALUE)

                    .header(HttpHeaders.AUTHORIZATION,operatorId)

                    .body(getCmdParam(vin))

                    .execute();

            logger.info("response: " + response.body());

            if (response.getStatus() != HttpStatus.OK.value()){

  passCases.addAndGet(1);

            }

            int cmdStatus=Integer.valueOf(JSONObject.parseObject(response.body()).getJSONObject("data").getString("cmdStatus")).intValue();

            if (response.getStatus() == HttpStatus.OK.value() && cmdStatus==7){

    passCases.addAndGet(1);

            }else{

              passCases.set(0);

            }

        } catch (Exception e) {

            e.printStackTrace();

        }

    }

}

4.prometheus.yml配置

scrape_configs:

  - job_name: 'prometheus'

    metrics_path: /prometheus

    static_configs:

    - targets: ['localhost:9000']

5.运行

本地运行访问:http://localhost:9504/actuator/prometheus  (说明:9504为项目端口号),访问成功如下图:

访问prometheus:http://localhost:9090  (说明需要本地先启动prometheus的客户端)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,976评论 6 513
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,249评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 167,449评论 0 360
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,433评论 1 296
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,460评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,132评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,721评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,641评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,180评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,267评论 3 339
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,408评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,076评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,767评论 3 332
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,255评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,386评论 1 271
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,764评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,413评论 2 358