2021-07-26 13:34:42 +02:00
|
|
|
package eu.dnetlib.repo.manager.controllers;
|
|
|
|
|
|
|
|
import eu.dnetlib.repo.manager.service.PiWikService;
|
2021-10-12 15:30:38 +02:00
|
|
|
import eu.dnetlib.repo.manager.service.RepositoryService;
|
|
|
|
import eu.dnetlib.repo.manager.service.RepositoryServiceImpl;
|
2021-07-26 13:34:42 +02:00
|
|
|
import io.micrometer.core.instrument.binder.jvm.DiskSpaceMetrics;
|
|
|
|
import io.micrometer.core.instrument.binder.jvm.JvmGcMetrics;
|
|
|
|
import io.micrometer.core.instrument.binder.jvm.JvmMemoryMetrics;
|
|
|
|
import io.micrometer.core.instrument.binder.jvm.JvmThreadMetrics;
|
|
|
|
import io.micrometer.core.instrument.binder.system.ProcessorMetrics;
|
|
|
|
import io.micrometer.core.instrument.binder.system.UptimeMetrics;
|
|
|
|
import io.micrometer.prometheus.PrometheusConfig;
|
|
|
|
import io.micrometer.prometheus.PrometheusMeterRegistry;
|
|
|
|
import io.prometheus.client.exporter.common.TextFormat;
|
2021-10-12 15:30:38 +02:00
|
|
|
import org.apache.log4j.Logger;
|
|
|
|
import org.json.JSONException;
|
2021-07-26 13:34:42 +02:00
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
import org.springframework.http.MediaType;
|
|
|
|
import org.springframework.web.bind.annotation.RequestMapping;
|
|
|
|
import org.springframework.web.bind.annotation.RequestMethod;
|
|
|
|
import org.springframework.web.bind.annotation.RestController;
|
|
|
|
|
|
|
|
import java.io.File;
|
|
|
|
|
|
|
|
|
|
|
|
@RestController
|
|
|
|
@RequestMapping("/actuator/prometheus")
|
|
|
|
public class PrometheusController { // TODO: remove this with migration to Spring Boot 2
|
2021-10-12 15:30:38 +02:00
|
|
|
private static final Logger LOGGER = Logger.getLogger(PrometheusController.class);
|
2021-07-26 13:34:42 +02:00
|
|
|
|
|
|
|
private final PiWikService piWikService;
|
2021-10-12 15:30:38 +02:00
|
|
|
private final RepositoryService repositoryService;
|
2021-07-26 13:34:42 +02:00
|
|
|
|
|
|
|
@Autowired
|
2021-10-12 15:30:38 +02:00
|
|
|
public PrometheusController(PiWikService piWikService, RepositoryService repositoryService) {
|
2021-07-26 13:34:42 +02:00
|
|
|
this.piWikService = piWikService;
|
2021-10-12 15:30:38 +02:00
|
|
|
this.repositoryService = repositoryService;
|
2021-07-26 13:34:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@RequestMapping(method = RequestMethod.GET, path = "", produces = MediaType.TEXT_PLAIN_VALUE)
|
|
|
|
public String getPiwikMetrics() {
|
|
|
|
PrometheusMeterRegistry registry = new PrometheusMeterRegistry(PrometheusConfig.DEFAULT);
|
2021-10-12 15:30:38 +02:00
|
|
|
registry.counter("provide_repositories_registered").increment(repositoryService.getTotalRegisteredRepositories());
|
|
|
|
registry.counter("provide_usagecounts_repositories_registered").increment(piWikService.getTotal());
|
2021-10-12 12:16:37 +02:00
|
|
|
registry.counter("provide_usagecounts_repositories_validated").increment(piWikService.getValidated(true));
|
2021-07-26 13:34:42 +02:00
|
|
|
|
2021-10-12 12:16:37 +02:00
|
|
|
return registry.scrape(TextFormat.CONTENT_TYPE_OPENMETRICS_100);
|
2021-07-26 13:34:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@RequestMapping(method = RequestMethod.GET, path = "metrics", produces = MediaType.TEXT_PLAIN_VALUE)
|
|
|
|
public String getMetrics() {
|
|
|
|
PrometheusMeterRegistry registry = new PrometheusMeterRegistry(PrometheusConfig.DEFAULT);
|
|
|
|
new JvmThreadMetrics().bindTo(registry);
|
|
|
|
new JvmGcMetrics().bindTo(registry);
|
|
|
|
new JvmMemoryMetrics().bindTo(registry);
|
|
|
|
new DiskSpaceMetrics(new File("/")).bindTo(registry);
|
|
|
|
new ProcessorMetrics().bindTo(registry); // metrics related to the CPU stats
|
|
|
|
new UptimeMetrics().bindTo(registry);
|
|
|
|
|
2021-10-12 12:16:37 +02:00
|
|
|
return registry.scrape(TextFormat.CONTENT_TYPE_OPENMETRICS_100);
|
2021-07-26 13:34:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|