A set of additional JVM process metrics for micrometer.io.
- get "real" memory usage of the JVM beyond its managed parts
- get ahold of that info from within the JVM in environments where you can't instrument from the outside (e.g. PaaS)
<dependency>
<groupId>io.github.mweirauch</groupId>
<artifactId>micrometer-jvm-extras</artifactId>
<version>x.y.z</version>
</dependency>/* Plain Java */
final MeterRegistry registry = new SimpleMeterRegistry();
new ProcessMemoryMetrics().bindTo(registry);
new ProcessThreadMetrics().bindTo(registry);/* With Spring */
@Bean
public MeterBinder processMemoryMetrics() {
return new ProcessMemoryMetrics();
}
@Bean
public MeterBinder processThreadMetrics() {
return new ProcessThreadMetrics();
}ProcessMemoryMetrics reads process-level memory information from /proc/self/status and cgroup control files.
All Meters are reporting in bytes.
Please note that
procfsand the cgroup subsystem are only available on Linux-based systems.
process.memory.vss: Virtual set size. The amount of virtual memory the process can access. Mostly irrelevant, but included for completeness sake.process.memory.rss: Resident set size. The amount of process memory currently in RAM.process.memory.swap: The amount of process memory paged out to swap.
process.memory.limit.soft: Soft memory limit imposed by the cgroup.process.memory.limit.hard: Hard memory limit imposed by the cgroup.process.memory.limit.swap: Swap memory limit imposed by the cgroup. For cgroup v1 systems this value represents the total memory+swap limit, while for cgroup v2 systems it represents the swap limit only.
ProcessThreadMetrics reads process-level thread information from /proc/self/status.
Please note that
procfsis only available on Linux-based systems.
process.threads: The number of process threads as seen by the operating system.process.threads.context.switches.voluntary: The accumulated number of voluntary context switches since application start. A voluntary context switch occurs when a thread is in a waiting or blocked state and the scheduler switches control to another thread.process.threads.context.switches.nonvoluntary: The accumulated number of non-voluntary context switches since application start. An involuntary context switch occurs when a thread consumed the whole time slice it was granted from the scheduler. The thread is suspended and control is switched to another thread.
- Requires Java 8 or higher
- This project strives to support a wider range of deployment scenarios. Thus the versions of
micrometer-coreandslf4j-apidependencies are chosen in a more defensive manner and don't necessarily reflect their latest available versions. Use your build and dependency management tool to manage the versions of these dependencies in your project. - Snapshot builds are pushed to Sonatype Maven Snapshots Repository on successful
mainbuilds. procfsdata is cached for1000msin order to relief the filesystem pressure whenMeters based on this data are queried by the registry one after another on collection run.