千分尺-特定指标的常用标签

时间:2018-12-25 21:09:11

标签: spring micrometer spring-micrometer

我试图弄清楚如何为特定指标设置通用标签。注意:我正在使用Cloudwatch监控系统。这是我所拥有的:

@Bean
public MeterRegistryCustomizer<MeterRegistry> metricsCommonTags() {
    return new MeterRegistryCustomizer<MeterRegistry>() {

        @Override
        public void customize(MeterRegistry registry) {
            registry.config()
                .meterFilter(MeterFilter.denyNameStartsWith("jvm.gc.pause"))
                .meterFilter(MeterFilter.denyNameStartsWith("logback"))
                .meterFilter(MeterFilter.denyNameStartsWith("process"))
                .meterFilter(MeterFilter.denyNameStartsWith("system.cpu"))
                .meterFilter(MeterFilter.denyNameStartsWith("jvm.buffer"))
                .meterFilter(MeterFilter.denyNameStartsWith("jvm.classes")
                .commonTags(Arrays.asList(Tag.of("instanceId", instanceId)));
        }
    };
}

我正在考虑类似于MeterFilter.allow("metric.name").tags("tag1","tag2")

的MeterFilter方法

Micrometer确实允许我在创建仪表时设置标签,但是这对启用Spring的仪表没有帮助。

看来,唯一的方法是创建两个MeterRegistryCustomizer对象,一个用于Spring指标,而我创建的任何自定义指标都需要公共标签,而另一个则不需要。

有什么办法可以实现我所缺少的吗?

2 个答案:

答案 0 :(得分:1)

如果要将标签添加到特定仪表,请将MeterFilter注册为bean。有关示例,请参见以下代码:https://github.com/izeye/sample-micrometer-spring-boot/blob/so-53925641/src/main/java/com/izeye/sample/config/MetricsConfig.java#L40-L52

答案 1 :(得分:0)

为了后代,这是我的代码解决方案。选择的答案建议使用@Autowired MeterFilter bean,但这对于我的特定用例不是必需的。

为了区分我使用的仪表和不想使用instanceId标签的仪表,我在不想使用instanceId标签的仪表上设置了“ AGG”标签键(即,它们是将在所有实例中汇总),然后将其删除。

@Bean
public MeterRegistryCustomizer<MeterRegistry> buildMeterRegistry() {
    return new MeterRegistryCustomizer<MeterRegistry>() {

        @Override
        public void customize(MeterRegistry registry) {
            registry.config()
                .meterFilter(new MeterFilter() {

                    @Override
                    public Meter.Id map(Meter.Id id) {

                        // Check for the "AGG" tag
                        if (id.getTag("AGG") != null) {
                            log.debug("Setting an aggregate meter: {} :: {}", id.getName(), id.getTags());
                            // Remove the "AGG" tag
                            List<Tag> tags = id.getTags().stream()
                                .filter(tag -> !StringUtils.equalsIgnoreCase(tag.getKey(), "AGG"))
                                .collect(Collectors.toList());

                            // Create a new Meter.Id
                            return new Meter.Id(id.getName(), tags, id.getBaseUnit(), id.getDescription(), id.getType());
                        }

                        // Create a new Meter.Id with the instanceId tag
                        return new Meter.Id(id.getName(), Arrays.asList(Tag.of("instanceId", instanceId)), id.getBaseUnit(), id.getDescription(), id.getType());
                    }
                })
                .meterFilter(MeterFilter.denyNameStartsWith("jvm.gc.pause"))
                .meterFilter(MeterFilter.denyNameStartsWith("logback"))
                .meterFilter(MeterFilter.denyNameStartsWith("process"))
                .meterFilter(MeterFilter.denyNameStartsWith("system.cpu"))
                .meterFilter(MeterFilter.denyNameStartsWith("jvm.buffer"))
                .meterFilter(MeterFilter.denyNameStartsWith("jvm.classes"));
        }
    };
}