Установка общих меток с помощью микрометра для метрик InfluxDB
У меня есть отдельный модуль, который содержит общие классы. Два из классов устанавливают общие теги для метрик для наших сервисов. Когда я запускаю службу, метрики (счетчики) отправляются в InfluxDb, но общие теги, установленные в MetricsConfiguration.java, не отправляются. Я запросил метрики в InfluxDb, а также такие теги, как service
а также env
там нет, все остальные, которые устанавливаются непосредственно со счетчиками.
Я довольно свеж с Spring, Spring Boot и Micrometer. Либо я неправильно понял документацию и настройку общих тегов, либо они не поддерживаются в счетчиках или в 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
bean-компонент может быть вызван до инициализации контекста, но я не уверен в этом? Что странно, когда я ставлю точку останова в 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, они инициализируются просто отлично.
0 ответов
Я использовал приведенный ниже код, чтобы добавить общие теги ко всем метрикам, отправляемым в InfluxDB.
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.util.Arrays;
import java.util.LinkedList;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.actuate.autoconfigure.metrics.MeterRegistryCustomizer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.env.Environment;
import io.micrometer.core.aop.TimedAspect;
import io.micrometer.core.instrument.MeterRegistry;
import io.micrometer.core.instrument.Tag;
@Configuration
public class MetricsConfig {
@Value("${spring.application.name}")
String applicationName;
@Autowired
private Environment environment;
@Bean
public TimedAspect timedAspect(MeterRegistry registry) {
return new TimedAspect(registry);
}
@Bean
MeterRegistryCustomizer<MeterRegistry> metricsCommonTags() {
String hostname = "";
try {
hostname = InetAddress.getLocalHost().getHostName().toString();
} catch (UnknownHostException e) {
hostname = "unknown";
}
List<Tag> tags = new LinkedList<>();
tags.add(Tag.of("hostname", hostname));
tags.add(Tag.of("applicationName", applicationName));
String activeProfiles = Arrays.stream(this.environment.getActiveProfiles()).reduce("",String::concat);
tags.add(Tag.of("environment", activeProfiles));
return registry -> registry.config().commonTags(tags);
}
}