semantic-conventions/semantic_conventions/metrics/process-runtime-jvm-metrics...

135 lines
4.9 KiB
YAML

groups:
- id: attributes.process.runtime.jvm.memory
type: attribute_group
brief: "Describes JVM memory metric attributes."
attributes:
- id: type
type:
allow_custom_values: false
members:
- id: heap
value: 'heap'
brief: 'Heap memory.'
- id: non_heap
value: 'non_heap'
brief: 'Non-heap memory'
requirement_level: recommended
brief: The type of memory.
examples: ["heap", "non_heap"]
- id: pool
type: string
requirement_level: recommended
brief: Name of the memory pool.
examples: ["G1 Old Gen", "G1 Eden space", "G1 Survivor Space"]
note: >
Pool names are generally obtained via
[MemoryPoolMXBean#getName()](https://docs.oracle.com/en/java/javase/11/docs/api/java.management/java/lang/management/MemoryPoolMXBean.html#getName()).
- id: metric.process.runtime.jvm.memory.usage
type: metric
metric_name: process.runtime.jvm.memory.usage
extends: attributes.process.runtime.jvm.memory
brief: "Measure of memory used."
instrument: updowncounter
unit: "By"
- id: metric.process.runtime.jvm.memory.committed
type: metric
metric_name: process.runtime.jvm.memory.committed
extends: attributes.process.runtime.jvm.memory
brief: "Measure of memory committed."
instrument: updowncounter
unit: "By"
- id: metric.process.runtime.jvm.memory.limit
type: metric
metric_name: process.runtime.jvm.memory.limit
extends: attributes.process.runtime.jvm.memory
brief: "Measure of max obtainable memory."
instrument: updowncounter
unit: "By"
- id: metric.process.runtime.jvm.memory.usage_after_last_gc
type: metric
metric_name: process.runtime.jvm.memory.usage_after_last_gc
extends: attributes.process.runtime.jvm.memory
brief: "Measure of memory used, as measured after the most recent garbage collection event on this pool."
instrument: updowncounter
unit: "By"
- id: metric.process.runtime.jvm.gc.duration
type: metric
metric_name: process.runtime.jvm.gc.duration
brief: "Duration of JVM garbage collection actions."
instrument: histogram
unit: "s"
attributes:
- id: gc
type: string
requirement_level: recommended
brief: Name of the garbage collector.
examples: ["G1 Young Generation", "G1 Old Generation"]
note: >
Garbage collector name is generally obtained via
[GarbageCollectionNotificationInfo#getGcName()](https://docs.oracle.com/en/java/javase/11/docs/api/jdk.management/com/sun/management/GarbageCollectionNotificationInfo.html#getGcName()).
- id: action
type: string
requirement_level: recommended
brief: Name of the garbage collector action.
examples: ["end of minor GC", "end of major GC"]
note: >
Garbage collector action is generally obtained via
[GarbageCollectionNotificationInfo#getGcAction()](https://docs.oracle.com/en/java/javase/11/docs/api/jdk.management/com/sun/management/GarbageCollectionNotificationInfo.html#getGcAction()).
- id: metric.process.runtime.jvm.threads.count
type: metric
metric_name: process.runtime.jvm.threads.count
brief: "Number of executing platform threads."
instrument: updowncounter
unit: "{thread}"
attributes:
- id: daemon
brief: "Whether the thread is daemon or not."
type: boolean
requirement_level: recommended
- id: metric.process.runtime.jvm.classes.loaded
type: metric
metric_name: process.runtime.jvm.classes.loaded
brief: "Number of classes loaded since JVM start."
instrument: counter
unit: "{class}"
- id: metric.process.runtime.jvm.classes.unloaded
type: metric
metric_name: process.runtime.jvm.classes.unloaded
brief: "Number of classes unloaded since JVM start."
instrument: counter
unit: "{class}"
- id: metric.process.runtime.jvm.classes.current_loaded
type: metric
metric_name: process.runtime.jvm.classes.current_loaded
brief: "Number of classes currently loaded."
instrument: updowncounter
unit: "{class}"
- id: metric.process.runtime.jvm.cpu.time
type: metric
metric_name: process.runtime.jvm.cpu.time
brief: "CPU time used by the process."
instrument: counter
unit: "s"
- id: metric.process.runtime.jvm.cpu.recent_utilization
type: metric
metric_name: process.runtime.jvm.cpu.recent_utilization
brief: "Recent CPU utilization for the process."
note: >
The value range is [0.0,1.0].
This utilization is not defined as being for the specific interval since last measurement
(unlike `system.cpu.utilization`).
[Reference](https://docs.oracle.com/en/java/javase/17/docs/api/jdk.management/com/sun/management/OperatingSystemMXBean.html#getProcessCpuLoad()).
instrument: gauge
unit: "1"