Skip to content

A Micrometer meter registry that generates JFR events

Notifications You must be signed in to change notification settings

marschall/micrometer-jfr

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Micrometer JFR Maven Central Javadocs

A Micrometer meter registry that generates JFR events.

Usage

Metrics.addRegistry(new JfrMeterRegistry());
<dependency>
  <groupId>com.github.marschall</groupId>
  <artifactId>micrometer-jfr</artifactId>
  <version>1.13.0</version>
</dependency>

Image of Spring Batch Micrometer JFR events

Features

  • Converts tags (key value pairs) into JFR event attributes.
  • Basic mapping from some io.micrometer.core.instrument.binder.BaseUnits to jdk.jfr.ContentType.
  • Maps Id#getName() and Id#getDescription() to @Name and @Description.
  • Stacktraces are disabled for all events for reduced overhead.
  • Generates a JFR event for every metered value.
  • A custom naming convention is used to translate tag names to capitalized words.

Limitations

  • The built in duration of most events is 0 instead a new attribute "Metered Duration" is added.

Configuration

The frequency of polled meters like FunctionCounter have to be configured in a .jfc file.

<event name="my.fcounter">
  <setting name="enabled">true</setting>
  <setting name="period">5 s</setting>
</event>

Compliance

We do not pass all tests in MeterRegistryCompatibilityKit. The main issue is that we do not implement histograms for Timer, LongTaskTimer and DistributionSummary. Instead we always generate a JFR event and let the consumer process and aggregate as desired.

In addition we do not support PauseDetector in Timer, we recommend you generate JFR events should the existing ones not be sufficient.

About

A Micrometer meter registry that generates JFR events

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages