• 可观测性-Metrics-统计每个指标的基数


    之前已经监控了很多metrics,现在我们需要监控metrics自身的一些指标,例如我们比较关注的是其每个指标的基数。基数太大会导致客户端和服务端内存溢出问题。

    相关代码如下

    import io.micrometer.core.instrument.Gauge;
    import io.micrometer.core.instrument.Meter;
    import io.micrometer.core.instrument.composite.CompositeMeterRegistry;
    import org.springframework.scheduling.annotation.Scheduled;
    import org.springframework.stereotype.Component;
    
    import java.util.List;
    import java.util.Map;
    import java.util.concurrent.ConcurrentHashMap;
    import java.util.stream.Collectors;
    
    
    @Component
    public class MetricsCardinalityScheduledTask {
        private final Map<String, Integer> meterCardinalityMap = new ConcurrentHashMap<>();
        private final CompositeMeterRegistry compositeMeterRegistry;
    
        public MetricsCardinalityScheduledTask(CompositeMeterRegistry compositeMeterRegistry) {
            this.compositeMeterRegistry = compositeMeterRegistry;
        }
    
        @Scheduled(fixedDelayString = "#{@lakerProperties.scheduleTaskDelayMilliseconds}")
        public void emitCardinalityForEachMeasurement() {
            // 清空
            meterCardinalityMap.clear();
            // 剔除自身的meter。
            List<Meter> registryMeters = compositeMeterRegistry.getMeters()
                                        .stream()
                                        .filter(meter -> !meter.getId().getName().equals("measurement.cardinality"))
                                        .collect(Collectors.toList());
            // 转换所有的Meters
            registryMeters
                    .forEach(meter -> meterCardinalityMap.merge(meter.getId().getName(), 1, Integer::sum));
    
            for (String measurement : meterCardinalityMap.keySet()) {
                Gauge.builder("measurement.cardinality",
                        () -> (long) meterCardinalityMap.get(measurement))
                        .tags("measurement", measurement)
                        .register(compositeMeterRegistry);
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42

    为什么上面的代码就可以统计基数呢?

    为此我们针对Meter解释下。

    Meter是以Id为唯一key,例如有2个指标memcpu

    mem

    • tag:ip,例如有 10.0.0.1,10.0.0.2

    cpu

    • tag:ip,例如有 10.0.0.1,10.0.0.2

    则Meter有4个.指标2个为memcpu

    nameid
    memmem:10.0.0.1
    memmem:10.0.0.2
    cpucpu:10.0.0.1
    cpucpu:10.0.0.2
  • 相关阅读:
    ACM-ICPC Northeastern European Regional Contest (NEERC 15) -Generators
    ISPRS2021/云检测:一种地理信息驱动的方法和一种新的大规模遥感云/雪检测数据集
    【UE】抓取物体
    C语言-扫雷游戏的实现
    HM-RocketMQ2.7【整体联调、项目优化】
    2022年加氢工艺考试题模拟考试平台操作
    C++模板详解
    synchronized关键字详解-偏向锁、轻量级锁、偏向锁、重量级锁、自旋、锁粗化、锁消除
    2024.06.03 校招 实习 内推 面经
    B_QuRT_User_Guide(26)
  • 原文地址:https://blog.csdn.net/abu935009066/article/details/127860783