All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.github.jhipster.config.metric.JHipsterLoggingMetricsExportConfiguration Maven / Gradle / Ivy

package io.github.jhipster.config.metric;

import com.codahale.metrics.MetricRegistry;
import com.codahale.metrics.Slf4jReporter;
import io.github.jhipster.config.JHipsterProperties;
import io.micrometer.core.instrument.Clock;
import io.micrometer.core.instrument.MeterRegistry;
import io.micrometer.core.instrument.dropwizard.DropwizardConfig;
import io.micrometer.core.instrument.dropwizard.DropwizardMeterRegistry;
import io.micrometer.core.instrument.util.HierarchicalNameMapper;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.slf4j.Marker;
import org.slf4j.MarkerFactory;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import java.util.concurrent.TimeUnit;

/**
 * Console Reporter Configuration
 * 

* Pass the metrics to the logs with Dropwizard Reporter implementation * see https://github.com/micrometer-metrics/micrometer-docs/blob/9fedeb5/src/docs/guide/console-reporter.adoc */ @Configuration @ConditionalOnProperty("jhipster.metrics.logs.enabled") public class JHipsterLoggingMetricsExportConfiguration { private final Logger log = LoggerFactory.getLogger(JHipsterLoggingMetricsExportConfiguration.class); private final JHipsterProperties jHipsterProperties; /** *

Constructor for JHipsterLoggingMetricsExportConfiguration.

* * @param jHipsterProperties a {@link io.github.jhipster.config.JHipsterProperties} object. */ public JHipsterLoggingMetricsExportConfiguration(JHipsterProperties jHipsterProperties) { this.jHipsterProperties = jHipsterProperties; } /** *

dropwizardRegistry.

* * @return a {@link com.codahale.metrics.MetricRegistry} object. */ @Bean public MetricRegistry dropwizardRegistry() { return new MetricRegistry(); } /** *

consoleReporter.

* * @param dropwizardRegistry a {@link com.codahale.metrics.MetricRegistry} object. * @return a {@link com.codahale.metrics.Slf4jReporter} object. */ @Bean public Slf4jReporter consoleReporter(MetricRegistry dropwizardRegistry) { log.info("Initializing Metrics Log reporting"); Marker metricsMarker = MarkerFactory.getMarker("metrics"); final Slf4jReporter reporter = Slf4jReporter.forRegistry(dropwizardRegistry) .outputTo(LoggerFactory.getLogger("metrics")) .markWith(metricsMarker) .convertRatesTo(TimeUnit.SECONDS) .convertDurationsTo(TimeUnit.MILLISECONDS) .build(); reporter.start(jHipsterProperties.getMetrics().getLogs().getReportFrequency(), TimeUnit.SECONDS); return reporter; } // Needed to enable the Console reporter // https://github.com/micrometer-metrics/micrometer-docs/blob/9fedeb5/src/docs/guide/console-reporter.adoc /** *

consoleLoggingRegistry.

* * @param dropwizardRegistry a {@link com.codahale.metrics.MetricRegistry} object. * @return a {@link io.micrometer.core.instrument.MeterRegistry} object. */ @Bean public MeterRegistry consoleLoggingRegistry(MetricRegistry dropwizardRegistry) { DropwizardConfig dropwizardConfig = new DropwizardConfig() { @Override public String prefix() { return "console"; } @Override public String get(String key) { return null; } }; return new DropwizardMeterRegistry(dropwizardConfig, dropwizardRegistry, HierarchicalNameMapper.DEFAULT, Clock.SYSTEM) { @Override protected Double nullGaugeValue() { return null; } }; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy