Установка общих меток с помощью микрометра для метрик InfluxDB - PullRequest
0 голосов
/ 06 февраля 2019

У меня есть отдельный модуль, который содержит общие классы.Два из классов устанавливают общие теги для метрик для наших сервисов.Когда я запускаю службу, метрики (счетчики) отправляются в InfluxDb, но общие теги, заданные в MetricsConfiguration.java, не отправляются.Я также запросил метрики в InfluxDb, и таких тегов, как service и env, там нет, все остальные, которые устанавливаются непосредственно со счетчиками, являются:

Я довольно свеж с Spring, Spring Boot имикрометр.Либо я неправильно понял документацию и конфигурацию общих тегов, либо они вообще не поддерживаются в счетчиках или InfluxDb в целом?

Версия микрометра: compile group: 'io.micrometer', name: 'micrometer-registry-influx', version: '1.0.5'

Проверка конечной точки /configprops, которую я вижу:

...
"metrics-com.example.io.metrics.MetricsProperties": {
    "prefix": "metrics",
    "properties": {
        "step": 0,
        "histogramExpiry": 0,
        "serviceTag": "service"
    }
}
...

и /env/spring.application.name дает:

...
"property": {
    "source": "applicationConfig: [classpath:/bootstrap.yml]",
    "value": "example-service"
},
...

Даже установка этого значения в свойствах конфигурации, похоже, не дает никакого эффекта:

environment: development

...

management:
  metrics:
    tags:
      env: "${environment}"
...

Проверкаконечная точка /env/management.metrics.tags.env показывает development.

С конечной точкой /beans я вижу загруженные бины:

...
"metricsCommonTags": {
    "aliases": [],
    "scope": "singleton",
    "type": "com.example.io.metrics.MetricsConfiguration$$Lambda$325/509806761",
    "resource": "com.example.io.metrics.MetricsConfiguration",
    "dependencies": []
},
"metricsConfiguration": {
    "aliases": [],
    "scope": "singleton",
    "type": "com.example.io.metrics.MetricsConfiguration$$EnhancerBySpringCGLIB$$f1b7dc1a",
    "resource": null,
    "dependencies": [
        "metrics-com.example.io.metrics.MetricsProperties",
        "org.springframework.context.annotation.AnnotationConfigApplicationContext@2ed3b1f5"
    ]
},
...
"metrics-com.example.io.metrics.MetricsProperties": {
    "aliases": [],
    "scope": "singleton",
    "type": "com.example.io.metrics.MetricsProperties",
    "resource": null,
    "dependencies": []
},
...

Итак, мой вопрос: я что-то упустил?

MetricsProperties.java

package com.example.io.metrics;

import org.springframework.boot.context.properties.ConfigurationProperties;

@ConfigurationProperties(prefix = "metrics")
public class MetricsProperties {
    private int histogramExpiry;
    private int step;
    private String serviceTag;

    public int getHistogramExpiry() {
        return histogramExpiry;
    }

    public void setHistogramExpiry(int histogramExpiry) {
        this.histogramExpiry = histogramExpiry;
    }

    public int getStep() {
        return step;
    }

    public void setStep(int step) {
        this.step = step;
    }

    public String getServiceTag() {
        return serviceTag;
    }

    public void setServiceTag(String serviceTag) {
        this.serviceTag = serviceTag;
    }
}

MetricsConfiguration.java

package com.example.io.metrics;

import io.micrometer.core.instrument.MeterRegistry;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.actuate.autoconfigure.metrics.MeterRegistryCustomizer;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
@EnableConfigurationProperties(MetricsProperties.class)
public class MetricsConfiguration {

    private final MetricsProperties metricsProperties;

    private final ApplicationContext applicationContext;

    @Autowired
    public MetricsConfiguration(MetricsProperties metricsProperties, ApplicationContext applicationContext) {
        this.metricsProperties = metricsProperties;
        this.applicationContext = applicationContext;
    }

    @Bean
    public MeterRegistryCustomizer<MeterRegistry> metricsCommonTags() {
        return registry -> registry
                .config()
                .commonTags(metricsProperties.getServiceTag(),
                        applicationContext.getApplicationName());
    }
}

РЕДАКТИРОВАТЬ:

Таким образом, у нас также есть /META-INF/spring.factories, заполненный:

org.springframework.cloud.bootstrap.BootstrapConfiguration = com.example.io.autoconfigure.CustomConfigServiceBootstrapConfiguration\
  ,com.example.io.metrics.MetricsConfiguration

CustomConfigServiceBootstrapConfiguration пропускается локально, потому что есть условие @ConditionalOnProperty(name = "autoconfigure.client.resolvePrivateServerAddress", matchIfMissing = true) и в bootstrap.yml есть

autoconfigure:
  client:
    resolvePrivateServerAddress: false

Я также провел некоторое исследование и выяснил, что бин metricsCommonTags мог быть вызван до инициализации контекста, но я нене уверен в этом?Странно то, что, когда я ставлю точку останова в metricsCommonTags, свойства еще не установлены с сервера Cloud Config.

Вот также урезанная версия Application.java:

import io.micrometer.core.instrument.MeterRegistry;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
import org.springframework.data.mongodb.repository.config.EnableMongoRepositories;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;

@SpringBootApplication
@EnableConfigurationProperties(LoginProperties.class)
@EnableJpaRepositories
@EnableMongoRepositories
@EnableSwagger2
@Configuration
@EnableWebMvc
public class Application implements WebMvcConfigurer {

    private final MeterRegistry meterRegistry;

    @Autowired
    public Application(MeterRegistry meterRegistry) {
        this.meterRegistry = meterRegistry;
    }

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

Для всего остального, где мы используем свойства с сервера Cloud Config, они инициализируются просто отлично.

...