1
0
mirror of https://github.com/open-telemetry/opentelemetry-go.git synced 2026-06-03 18:35:08 +02:00
Files
opentelemetry-go/semconv/v1.40.0/systemconv/metric.go
T

3827 lines
106 KiB
Go

// Code generated from semantic convention specification. DO NOT EDIT.
// Copyright The OpenTelemetry Authors
// SPDX-License-Identifier: Apache-2.0
// Package systemconv provides types and functionality for OpenTelemetry semantic
// conventions in the "system" namespace.
package systemconv
import (
"context"
"sync"
"go.opentelemetry.io/otel/attribute"
"go.opentelemetry.io/otel/metric"
"go.opentelemetry.io/otel/metric/noop"
)
var (
addOptPool = &sync.Pool{New: func() any { return &[]metric.AddOption{} }}
recOptPool = &sync.Pool{New: func() any { return &[]metric.RecordOption{} }}
)
// CPUModeAttr is an attribute conforming to the cpu.mode semantic conventions.
// It represents the mode of the CPU.
type CPUModeAttr string
var (
// CPUModeUser is the user.
CPUModeUser CPUModeAttr = "user"
// CPUModeSystem is the system.
CPUModeSystem CPUModeAttr = "system"
// CPUModeNice is the nice.
CPUModeNice CPUModeAttr = "nice"
// CPUModeIdle is the idle.
CPUModeIdle CPUModeAttr = "idle"
// CPUModeIOWait is the IO Wait.
CPUModeIOWait CPUModeAttr = "iowait"
// CPUModeInterrupt is the interrupt.
CPUModeInterrupt CPUModeAttr = "interrupt"
// CPUModeSteal is the steal.
CPUModeSteal CPUModeAttr = "steal"
// CPUModeKernel is the kernel.
CPUModeKernel CPUModeAttr = "kernel"
)
// DiskIODirectionAttr is an attribute conforming to the disk.io.direction
// semantic conventions. It represents the disk IO operation direction.
type DiskIODirectionAttr string
var (
// DiskIODirectionRead is the standardized value "read" of DiskIODirectionAttr.
DiskIODirectionRead DiskIODirectionAttr = "read"
// DiskIODirectionWrite is the standardized value "write" of
// DiskIODirectionAttr.
DiskIODirectionWrite DiskIODirectionAttr = "write"
)
// NetworkConnectionStateAttr is an attribute conforming to the
// network.connection.state semantic conventions. It represents the state of
// network connection.
type NetworkConnectionStateAttr string
var (
// NetworkConnectionStateClosed is the standardized value "closed" of
// NetworkConnectionStateAttr.
NetworkConnectionStateClosed NetworkConnectionStateAttr = "closed"
// NetworkConnectionStateCloseWait is the standardized value "close_wait" of
// NetworkConnectionStateAttr.
NetworkConnectionStateCloseWait NetworkConnectionStateAttr = "close_wait"
// NetworkConnectionStateClosing is the standardized value "closing" of
// NetworkConnectionStateAttr.
NetworkConnectionStateClosing NetworkConnectionStateAttr = "closing"
// NetworkConnectionStateEstablished is the standardized value "established" of
// NetworkConnectionStateAttr.
NetworkConnectionStateEstablished NetworkConnectionStateAttr = "established"
// NetworkConnectionStateFinWait1 is the standardized value "fin_wait_1" of
// NetworkConnectionStateAttr.
NetworkConnectionStateFinWait1 NetworkConnectionStateAttr = "fin_wait_1"
// NetworkConnectionStateFinWait2 is the standardized value "fin_wait_2" of
// NetworkConnectionStateAttr.
NetworkConnectionStateFinWait2 NetworkConnectionStateAttr = "fin_wait_2"
// NetworkConnectionStateLastAck is the standardized value "last_ack" of
// NetworkConnectionStateAttr.
NetworkConnectionStateLastAck NetworkConnectionStateAttr = "last_ack"
// NetworkConnectionStateListen is the standardized value "listen" of
// NetworkConnectionStateAttr.
NetworkConnectionStateListen NetworkConnectionStateAttr = "listen"
// NetworkConnectionStateSynReceived is the standardized value "syn_received" of
// NetworkConnectionStateAttr.
NetworkConnectionStateSynReceived NetworkConnectionStateAttr = "syn_received"
// NetworkConnectionStateSynSent is the standardized value "syn_sent" of
// NetworkConnectionStateAttr.
NetworkConnectionStateSynSent NetworkConnectionStateAttr = "syn_sent"
// NetworkConnectionStateTimeWait is the standardized value "time_wait" of
// NetworkConnectionStateAttr.
NetworkConnectionStateTimeWait NetworkConnectionStateAttr = "time_wait"
)
// NetworkIODirectionAttr is an attribute conforming to the network.io.direction
// semantic conventions. It represents the network IO operation direction.
type NetworkIODirectionAttr string
var (
// NetworkIODirectionTransmit is the standardized value "transmit" of
// NetworkIODirectionAttr.
NetworkIODirectionTransmit NetworkIODirectionAttr = "transmit"
// NetworkIODirectionReceive is the standardized value "receive" of
// NetworkIODirectionAttr.
NetworkIODirectionReceive NetworkIODirectionAttr = "receive"
)
// NetworkTransportAttr is an attribute conforming to the network.transport
// semantic conventions. It represents the [OSI transport layer] or
// [inter-process communication method].
//
// [OSI transport layer]: https://wikipedia.org/wiki/Transport_layer
// [inter-process communication method]: https://wikipedia.org/wiki/Inter-process_communication
type NetworkTransportAttr string
var (
// NetworkTransportTCP is the TCP.
NetworkTransportTCP NetworkTransportAttr = "tcp"
// NetworkTransportUDP is the UDP.
NetworkTransportUDP NetworkTransportAttr = "udp"
// NetworkTransportPipe is the named or anonymous pipe.
NetworkTransportPipe NetworkTransportAttr = "pipe"
// NetworkTransportUnix is the unix domain socket.
NetworkTransportUnix NetworkTransportAttr = "unix"
// NetworkTransportQUIC is the QUIC.
NetworkTransportQUIC NetworkTransportAttr = "quic"
)
// ProcessStateAttr is an attribute conforming to the process.state semantic
// conventions. It represents the process state, e.g.,
// [Linux Process State Codes].
//
// [Linux Process State Codes]: https://man7.org/linux/man-pages/man1/ps.1.html#PROCESS_STATE_CODES
type ProcessStateAttr string
var (
// ProcessStateRunning is the standardized value "running" of ProcessStateAttr.
ProcessStateRunning ProcessStateAttr = "running"
// ProcessStateSleeping is the standardized value "sleeping" of
// ProcessStateAttr.
ProcessStateSleeping ProcessStateAttr = "sleeping"
// ProcessStateStopped is the standardized value "stopped" of ProcessStateAttr.
ProcessStateStopped ProcessStateAttr = "stopped"
// ProcessStateDefunct is the standardized value "defunct" of ProcessStateAttr.
ProcessStateDefunct ProcessStateAttr = "defunct"
)
// FilesystemStateAttr is an attribute conforming to the system.filesystem.state
// semantic conventions. It represents the filesystem state.
type FilesystemStateAttr string
var (
// FilesystemStateUsed is the standardized value "used" of FilesystemStateAttr.
FilesystemStateUsed FilesystemStateAttr = "used"
// FilesystemStateFree is the standardized value "free" of FilesystemStateAttr.
FilesystemStateFree FilesystemStateAttr = "free"
// FilesystemStateReserved is the standardized value "reserved" of
// FilesystemStateAttr.
FilesystemStateReserved FilesystemStateAttr = "reserved"
)
// FilesystemTypeAttr is an attribute conforming to the system.filesystem.type
// semantic conventions. It represents the filesystem type.
type FilesystemTypeAttr string
var (
// FilesystemTypeFat32 is the standardized value "fat32" of FilesystemTypeAttr.
FilesystemTypeFat32 FilesystemTypeAttr = "fat32"
// FilesystemTypeExfat is the standardized value "exfat" of FilesystemTypeAttr.
FilesystemTypeExfat FilesystemTypeAttr = "exfat"
// FilesystemTypeNtfs is the standardized value "ntfs" of FilesystemTypeAttr.
FilesystemTypeNtfs FilesystemTypeAttr = "ntfs"
// FilesystemTypeRefs is the standardized value "refs" of FilesystemTypeAttr.
FilesystemTypeRefs FilesystemTypeAttr = "refs"
// FilesystemTypeHfsplus is the standardized value "hfsplus" of
// FilesystemTypeAttr.
FilesystemTypeHfsplus FilesystemTypeAttr = "hfsplus"
// FilesystemTypeExt4 is the standardized value "ext4" of FilesystemTypeAttr.
FilesystemTypeExt4 FilesystemTypeAttr = "ext4"
)
// MemoryLinuxSlabStateAttr is an attribute conforming to the
// system.memory.linux.slab.state semantic conventions. It represents the Linux
// Slab memory state.
type MemoryLinuxSlabStateAttr string
var (
// MemoryLinuxSlabStateReclaimable is the standardized value "reclaimable" of
// MemoryLinuxSlabStateAttr.
MemoryLinuxSlabStateReclaimable MemoryLinuxSlabStateAttr = "reclaimable"
// MemoryLinuxSlabStateUnreclaimable is the standardized value "unreclaimable"
// of MemoryLinuxSlabStateAttr.
MemoryLinuxSlabStateUnreclaimable MemoryLinuxSlabStateAttr = "unreclaimable"
)
// MemoryStateAttr is an attribute conforming to the system.memory.state semantic
// conventions. It represents the memory state.
type MemoryStateAttr string
var (
// MemoryStateUsed is the actual used virtual memory in bytes.
MemoryStateUsed MemoryStateAttr = "used"
// MemoryStateFree is the standardized value "free" of MemoryStateAttr.
MemoryStateFree MemoryStateAttr = "free"
// MemoryStateBuffers is the standardized value "buffers" of MemoryStateAttr.
MemoryStateBuffers MemoryStateAttr = "buffers"
// MemoryStateCached is the standardized value "cached" of MemoryStateAttr.
MemoryStateCached MemoryStateAttr = "cached"
)
// PagingDirectionAttr is an attribute conforming to the system.paging.direction
// semantic conventions. It represents the paging access direction.
type PagingDirectionAttr string
var (
// PagingDirectionIn is the standardized value "in" of PagingDirectionAttr.
PagingDirectionIn PagingDirectionAttr = "in"
// PagingDirectionOut is the standardized value "out" of PagingDirectionAttr.
PagingDirectionOut PagingDirectionAttr = "out"
)
// PagingFaultTypeAttr is an attribute conforming to the system.paging.fault.type
// semantic conventions. It represents the paging fault type.
type PagingFaultTypeAttr string
var (
// PagingFaultTypeMajor is the standardized value "major" of
// PagingFaultTypeAttr.
PagingFaultTypeMajor PagingFaultTypeAttr = "major"
// PagingFaultTypeMinor is the standardized value "minor" of
// PagingFaultTypeAttr.
PagingFaultTypeMinor PagingFaultTypeAttr = "minor"
)
// PagingStateAttr is an attribute conforming to the system.paging.state semantic
// conventions. It represents the memory paging state.
type PagingStateAttr string
var (
// PagingStateUsed is the standardized value "used" of PagingStateAttr.
PagingStateUsed PagingStateAttr = "used"
// PagingStateFree is the standardized value "free" of PagingStateAttr.
PagingStateFree PagingStateAttr = "free"
)
// CPUFrequency is an instrument used to record metric values conforming to the
// "system.cpu.frequency" semantic conventions. It represents the operating
// frequency of the logical CPU in Hertz.
type CPUFrequency struct {
metric.Int64Gauge
}
var newCPUFrequencyOpts = []metric.Int64GaugeOption{
metric.WithDescription("Operating frequency of the logical CPU in Hertz."),
metric.WithUnit("Hz"),
}
// NewCPUFrequency returns a new CPUFrequency instrument.
func NewCPUFrequency(
m metric.Meter,
opt ...metric.Int64GaugeOption,
) (CPUFrequency, error) {
// Check if the meter is nil.
if m == nil {
return CPUFrequency{noop.Int64Gauge{}}, nil
}
if len(opt) == 0 {
opt = newCPUFrequencyOpts
} else {
opt = append(opt, newCPUFrequencyOpts...)
}
i, err := m.Int64Gauge(
"system.cpu.frequency",
opt...,
)
if err != nil {
return CPUFrequency{noop.Int64Gauge{}}, err
}
return CPUFrequency{i}, nil
}
// Inst returns the underlying metric instrument.
func (m CPUFrequency) Inst() metric.Int64Gauge {
return m.Int64Gauge
}
// Name returns the semantic convention name of the instrument.
func (CPUFrequency) Name() string {
return "system.cpu.frequency"
}
// Unit returns the semantic convention unit of the instrument
func (CPUFrequency) Unit() string {
return "Hz"
}
// Description returns the semantic convention description of the instrument
func (CPUFrequency) Description() string {
return "Operating frequency of the logical CPU in Hertz."
}
// Record records val to the current distribution for attrs.
//
// All additional attrs passed are included in the recorded value.
func (m CPUFrequency) Record(
ctx context.Context,
val int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64Gauge.Record(ctx, val)
return
}
o := recOptPool.Get().(*[]metric.RecordOption)
defer func() {
*o = (*o)[:0]
recOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64Gauge.Record(ctx, val, *o...)
}
// RecordSet records val to the current distribution for set.
func (m CPUFrequency) RecordSet(ctx context.Context, val int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64Gauge.Record(ctx, val)
return
}
o := recOptPool.Get().(*[]metric.RecordOption)
defer func() {
*o = (*o)[:0]
recOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64Gauge.Record(ctx, val, *o...)
}
// AttrCPULogicalNumber returns an optional attribute for the
// "cpu.logical_number" semantic convention. It represents the logical CPU number
// [0..n-1].
func (CPUFrequency) AttrCPULogicalNumber(val int) attribute.KeyValue {
return attribute.Int("cpu.logical_number", val)
}
// CPULogicalCount is an instrument used to record metric values conforming to
// the "system.cpu.logical.count" semantic conventions. It represents the reports
// the number of logical (virtual) processor cores created by the operating
// system to manage multitasking.
type CPULogicalCount struct {
metric.Int64UpDownCounter
}
var newCPULogicalCountOpts = []metric.Int64UpDownCounterOption{
metric.WithDescription("Reports the number of logical (virtual) processor cores created by the operating system to manage multitasking."),
metric.WithUnit("{cpu}"),
}
// NewCPULogicalCount returns a new CPULogicalCount instrument.
func NewCPULogicalCount(
m metric.Meter,
opt ...metric.Int64UpDownCounterOption,
) (CPULogicalCount, error) {
// Check if the meter is nil.
if m == nil {
return CPULogicalCount{noop.Int64UpDownCounter{}}, nil
}
if len(opt) == 0 {
opt = newCPULogicalCountOpts
} else {
opt = append(opt, newCPULogicalCountOpts...)
}
i, err := m.Int64UpDownCounter(
"system.cpu.logical.count",
opt...,
)
if err != nil {
return CPULogicalCount{noop.Int64UpDownCounter{}}, err
}
return CPULogicalCount{i}, nil
}
// Inst returns the underlying metric instrument.
func (m CPULogicalCount) Inst() metric.Int64UpDownCounter {
return m.Int64UpDownCounter
}
// Name returns the semantic convention name of the instrument.
func (CPULogicalCount) Name() string {
return "system.cpu.logical.count"
}
// Unit returns the semantic convention unit of the instrument
func (CPULogicalCount) Unit() string {
return "{cpu}"
}
// Description returns the semantic convention description of the instrument
func (CPULogicalCount) Description() string {
return "Reports the number of logical (virtual) processor cores created by the operating system to manage multitasking."
}
// Add adds incr to the existing count for attrs.
//
// Calculated by multiplying the number of sockets by the number of cores per
// socket, and then by the number of threads per core
func (m CPULogicalCount) Add(ctx context.Context, incr int64, attrs ...attribute.KeyValue) {
if len(attrs) == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributes(attrs...))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
//
// Calculated by multiplying the number of sockets by the number of cores per
// socket, and then by the number of threads per core
func (m CPULogicalCount) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// CPUPhysicalCount is an instrument used to record metric values conforming to
// the "system.cpu.physical.count" semantic conventions. It represents the
// reports the number of actual physical processor cores on the hardware.
type CPUPhysicalCount struct {
metric.Int64UpDownCounter
}
var newCPUPhysicalCountOpts = []metric.Int64UpDownCounterOption{
metric.WithDescription("Reports the number of actual physical processor cores on the hardware."),
metric.WithUnit("{cpu}"),
}
// NewCPUPhysicalCount returns a new CPUPhysicalCount instrument.
func NewCPUPhysicalCount(
m metric.Meter,
opt ...metric.Int64UpDownCounterOption,
) (CPUPhysicalCount, error) {
// Check if the meter is nil.
if m == nil {
return CPUPhysicalCount{noop.Int64UpDownCounter{}}, nil
}
if len(opt) == 0 {
opt = newCPUPhysicalCountOpts
} else {
opt = append(opt, newCPUPhysicalCountOpts...)
}
i, err := m.Int64UpDownCounter(
"system.cpu.physical.count",
opt...,
)
if err != nil {
return CPUPhysicalCount{noop.Int64UpDownCounter{}}, err
}
return CPUPhysicalCount{i}, nil
}
// Inst returns the underlying metric instrument.
func (m CPUPhysicalCount) Inst() metric.Int64UpDownCounter {
return m.Int64UpDownCounter
}
// Name returns the semantic convention name of the instrument.
func (CPUPhysicalCount) Name() string {
return "system.cpu.physical.count"
}
// Unit returns the semantic convention unit of the instrument
func (CPUPhysicalCount) Unit() string {
return "{cpu}"
}
// Description returns the semantic convention description of the instrument
func (CPUPhysicalCount) Description() string {
return "Reports the number of actual physical processor cores on the hardware."
}
// Add adds incr to the existing count for attrs.
//
// Calculated by multiplying the number of sockets by the number of cores per
// socket
func (m CPUPhysicalCount) Add(ctx context.Context, incr int64, attrs ...attribute.KeyValue) {
if len(attrs) == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributes(attrs...))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
//
// Calculated by multiplying the number of sockets by the number of cores per
// socket
func (m CPUPhysicalCount) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// CPUTime is an instrument used to record metric values conforming to the
// "system.cpu.time" semantic conventions. It represents the seconds each logical
// CPU spent on each mode.
type CPUTime struct {
metric.Float64ObservableCounter
}
var newCPUTimeOpts = []metric.Float64ObservableCounterOption{
metric.WithDescription("Seconds each logical CPU spent on each mode."),
metric.WithUnit("s"),
}
// NewCPUTime returns a new CPUTime instrument.
func NewCPUTime(
m metric.Meter,
opt ...metric.Float64ObservableCounterOption,
) (CPUTime, error) {
// Check if the meter is nil.
if m == nil {
return CPUTime{noop.Float64ObservableCounter{}}, nil
}
if len(opt) == 0 {
opt = newCPUTimeOpts
} else {
opt = append(opt, newCPUTimeOpts...)
}
i, err := m.Float64ObservableCounter(
"system.cpu.time",
opt...,
)
if err != nil {
return CPUTime{noop.Float64ObservableCounter{}}, err
}
return CPUTime{i}, nil
}
// Inst returns the underlying metric instrument.
func (m CPUTime) Inst() metric.Float64ObservableCounter {
return m.Float64ObservableCounter
}
// Name returns the semantic convention name of the instrument.
func (CPUTime) Name() string {
return "system.cpu.time"
}
// Unit returns the semantic convention unit of the instrument
func (CPUTime) Unit() string {
return "s"
}
// Description returns the semantic convention description of the instrument
func (CPUTime) Description() string {
return "Seconds each logical CPU spent on each mode."
}
// AttrCPUMode returns an optional attribute for the "cpu.mode" semantic
// convention. It represents the mode of the CPU.
func (CPUTime) AttrCPUMode(val CPUModeAttr) attribute.KeyValue {
return attribute.String("cpu.mode", string(val))
}
// AttrCPULogicalNumber returns an optional attribute for the
// "cpu.logical_number" semantic convention. It represents the logical CPU number
// [0..n-1].
func (CPUTime) AttrCPULogicalNumber(val int) attribute.KeyValue {
return attribute.Int("cpu.logical_number", val)
}
// CPUUtilization is an instrument used to record metric values conforming to the
// "system.cpu.utilization" semantic conventions. It represents the for each
// logical CPU, the utilization is calculated as the change in cumulative CPU
// time (cpu.time) over a measurement interval, divided by the elapsed time.
type CPUUtilization struct {
metric.Int64Gauge
}
var newCPUUtilizationOpts = []metric.Int64GaugeOption{
metric.WithDescription("For each logical CPU, the utilization is calculated as the change in cumulative CPU time (cpu.time) over a measurement interval, divided by the elapsed time."),
metric.WithUnit("1"),
}
// NewCPUUtilization returns a new CPUUtilization instrument.
func NewCPUUtilization(
m metric.Meter,
opt ...metric.Int64GaugeOption,
) (CPUUtilization, error) {
// Check if the meter is nil.
if m == nil {
return CPUUtilization{noop.Int64Gauge{}}, nil
}
if len(opt) == 0 {
opt = newCPUUtilizationOpts
} else {
opt = append(opt, newCPUUtilizationOpts...)
}
i, err := m.Int64Gauge(
"system.cpu.utilization",
opt...,
)
if err != nil {
return CPUUtilization{noop.Int64Gauge{}}, err
}
return CPUUtilization{i}, nil
}
// Inst returns the underlying metric instrument.
func (m CPUUtilization) Inst() metric.Int64Gauge {
return m.Int64Gauge
}
// Name returns the semantic convention name of the instrument.
func (CPUUtilization) Name() string {
return "system.cpu.utilization"
}
// Unit returns the semantic convention unit of the instrument
func (CPUUtilization) Unit() string {
return "1"
}
// Description returns the semantic convention description of the instrument
func (CPUUtilization) Description() string {
return "For each logical CPU, the utilization is calculated as the change in cumulative CPU time (cpu.time) over a measurement interval, divided by the elapsed time."
}
// Record records val to the current distribution for attrs.
//
// All additional attrs passed are included in the recorded value.
func (m CPUUtilization) Record(
ctx context.Context,
val int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64Gauge.Record(ctx, val)
return
}
o := recOptPool.Get().(*[]metric.RecordOption)
defer func() {
*o = (*o)[:0]
recOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64Gauge.Record(ctx, val, *o...)
}
// RecordSet records val to the current distribution for set.
func (m CPUUtilization) RecordSet(ctx context.Context, val int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64Gauge.Record(ctx, val)
return
}
o := recOptPool.Get().(*[]metric.RecordOption)
defer func() {
*o = (*o)[:0]
recOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64Gauge.Record(ctx, val, *o...)
}
// AttrCPUMode returns an optional attribute for the "cpu.mode" semantic
// convention. It represents the mode of the CPU.
func (CPUUtilization) AttrCPUMode(val CPUModeAttr) attribute.KeyValue {
return attribute.String("cpu.mode", string(val))
}
// AttrCPULogicalNumber returns an optional attribute for the
// "cpu.logical_number" semantic convention. It represents the logical CPU number
// [0..n-1].
func (CPUUtilization) AttrCPULogicalNumber(val int) attribute.KeyValue {
return attribute.Int("cpu.logical_number", val)
}
// DiskIO is an instrument used to record metric values conforming to the
// "system.disk.io" semantic conventions. It represents the disk bytes
// transferred.
type DiskIO struct {
metric.Int64Counter
}
var newDiskIOOpts = []metric.Int64CounterOption{
metric.WithDescription("Disk bytes transferred."),
metric.WithUnit("By"),
}
// NewDiskIO returns a new DiskIO instrument.
func NewDiskIO(
m metric.Meter,
opt ...metric.Int64CounterOption,
) (DiskIO, error) {
// Check if the meter is nil.
if m == nil {
return DiskIO{noop.Int64Counter{}}, nil
}
if len(opt) == 0 {
opt = newDiskIOOpts
} else {
opt = append(opt, newDiskIOOpts...)
}
i, err := m.Int64Counter(
"system.disk.io",
opt...,
)
if err != nil {
return DiskIO{noop.Int64Counter{}}, err
}
return DiskIO{i}, nil
}
// Inst returns the underlying metric instrument.
func (m DiskIO) Inst() metric.Int64Counter {
return m.Int64Counter
}
// Name returns the semantic convention name of the instrument.
func (DiskIO) Name() string {
return "system.disk.io"
}
// Unit returns the semantic convention unit of the instrument
func (DiskIO) Unit() string {
return "By"
}
// Description returns the semantic convention description of the instrument
func (DiskIO) Description() string {
return "Disk bytes transferred."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
func (m DiskIO) Add(
ctx context.Context,
incr int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64Counter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
func (m DiskIO) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64Counter.Add(ctx, incr, *o...)
}
// AttrDiskIODirection returns an optional attribute for the "disk.io.direction"
// semantic convention. It represents the disk IO operation direction.
func (DiskIO) AttrDiskIODirection(val DiskIODirectionAttr) attribute.KeyValue {
return attribute.String("disk.io.direction", string(val))
}
// AttrDevice returns an optional attribute for the "system.device" semantic
// convention. It represents the device identifier.
func (DiskIO) AttrDevice(val string) attribute.KeyValue {
return attribute.String("system.device", val)
}
// DiskIOTime is an instrument used to record metric values conforming to the
// "system.disk.io_time" semantic conventions. It represents the time disk spent
// activated.
type DiskIOTime struct {
metric.Float64Counter
}
var newDiskIOTimeOpts = []metric.Float64CounterOption{
metric.WithDescription("Time disk spent activated."),
metric.WithUnit("s"),
}
// NewDiskIOTime returns a new DiskIOTime instrument.
func NewDiskIOTime(
m metric.Meter,
opt ...metric.Float64CounterOption,
) (DiskIOTime, error) {
// Check if the meter is nil.
if m == nil {
return DiskIOTime{noop.Float64Counter{}}, nil
}
if len(opt) == 0 {
opt = newDiskIOTimeOpts
} else {
opt = append(opt, newDiskIOTimeOpts...)
}
i, err := m.Float64Counter(
"system.disk.io_time",
opt...,
)
if err != nil {
return DiskIOTime{noop.Float64Counter{}}, err
}
return DiskIOTime{i}, nil
}
// Inst returns the underlying metric instrument.
func (m DiskIOTime) Inst() metric.Float64Counter {
return m.Float64Counter
}
// Name returns the semantic convention name of the instrument.
func (DiskIOTime) Name() string {
return "system.disk.io_time"
}
// Unit returns the semantic convention unit of the instrument
func (DiskIOTime) Unit() string {
return "s"
}
// Description returns the semantic convention description of the instrument
func (DiskIOTime) Description() string {
return "Time disk spent activated."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
//
// The real elapsed time ("wall clock") used in the I/O path (time from
// operations running in parallel are not counted). Measured as:
//
// - Linux: Field 13 from [procfs-diskstats]
// - Windows: The complement of
// ["Disk% Idle Time"]
// performance counter: `uptime * (100 - "Disk\% Idle Time") / 100`
//
//
// [procfs-diskstats]: https://www.kernel.org/doc/Documentation/ABI/testing/procfs-diskstats
// ["Disk% Idle Time"]: https://learn.microsoft.com/archive/blogs/askcore/windows-performance-monitor-disk-counters-explained#windows-performance-monitor-disk-counters-explained
func (m DiskIOTime) Add(
ctx context.Context,
incr float64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Float64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Float64Counter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
//
// The real elapsed time ("wall clock") used in the I/O path (time from
// operations running in parallel are not counted). Measured as:
//
// - Linux: Field 13 from [procfs-diskstats]
// - Windows: The complement of
// ["Disk% Idle Time"]
// performance counter: `uptime * (100 - "Disk\% Idle Time") / 100`
//
//
// [procfs-diskstats]: https://www.kernel.org/doc/Documentation/ABI/testing/procfs-diskstats
// ["Disk% Idle Time"]: https://learn.microsoft.com/archive/blogs/askcore/windows-performance-monitor-disk-counters-explained#windows-performance-monitor-disk-counters-explained
func (m DiskIOTime) AddSet(ctx context.Context, incr float64, set attribute.Set) {
if set.Len() == 0 {
m.Float64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Float64Counter.Add(ctx, incr, *o...)
}
// AttrDevice returns an optional attribute for the "system.device" semantic
// convention. It represents the device identifier.
func (DiskIOTime) AttrDevice(val string) attribute.KeyValue {
return attribute.String("system.device", val)
}
// DiskLimit is an instrument used to record metric values conforming to the
// "system.disk.limit" semantic conventions. It represents the total storage
// capacity of the disk.
type DiskLimit struct {
metric.Int64UpDownCounter
}
var newDiskLimitOpts = []metric.Int64UpDownCounterOption{
metric.WithDescription("The total storage capacity of the disk."),
metric.WithUnit("By"),
}
// NewDiskLimit returns a new DiskLimit instrument.
func NewDiskLimit(
m metric.Meter,
opt ...metric.Int64UpDownCounterOption,
) (DiskLimit, error) {
// Check if the meter is nil.
if m == nil {
return DiskLimit{noop.Int64UpDownCounter{}}, nil
}
if len(opt) == 0 {
opt = newDiskLimitOpts
} else {
opt = append(opt, newDiskLimitOpts...)
}
i, err := m.Int64UpDownCounter(
"system.disk.limit",
opt...,
)
if err != nil {
return DiskLimit{noop.Int64UpDownCounter{}}, err
}
return DiskLimit{i}, nil
}
// Inst returns the underlying metric instrument.
func (m DiskLimit) Inst() metric.Int64UpDownCounter {
return m.Int64UpDownCounter
}
// Name returns the semantic convention name of the instrument.
func (DiskLimit) Name() string {
return "system.disk.limit"
}
// Unit returns the semantic convention unit of the instrument
func (DiskLimit) Unit() string {
return "By"
}
// Description returns the semantic convention description of the instrument
func (DiskLimit) Description() string {
return "The total storage capacity of the disk."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
func (m DiskLimit) Add(
ctx context.Context,
incr int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
func (m DiskLimit) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AttrDevice returns an optional attribute for the "system.device" semantic
// convention. It represents the device identifier.
func (DiskLimit) AttrDevice(val string) attribute.KeyValue {
return attribute.String("system.device", val)
}
// DiskMerged is an instrument used to record metric values conforming to the
// "system.disk.merged" semantic conventions. It represents the number of disk
// reads/writes merged into single physical disk access operations.
type DiskMerged struct {
metric.Int64Counter
}
var newDiskMergedOpts = []metric.Int64CounterOption{
metric.WithDescription("The number of disk reads/writes merged into single physical disk access operations."),
metric.WithUnit("{operation}"),
}
// NewDiskMerged returns a new DiskMerged instrument.
func NewDiskMerged(
m metric.Meter,
opt ...metric.Int64CounterOption,
) (DiskMerged, error) {
// Check if the meter is nil.
if m == nil {
return DiskMerged{noop.Int64Counter{}}, nil
}
if len(opt) == 0 {
opt = newDiskMergedOpts
} else {
opt = append(opt, newDiskMergedOpts...)
}
i, err := m.Int64Counter(
"system.disk.merged",
opt...,
)
if err != nil {
return DiskMerged{noop.Int64Counter{}}, err
}
return DiskMerged{i}, nil
}
// Inst returns the underlying metric instrument.
func (m DiskMerged) Inst() metric.Int64Counter {
return m.Int64Counter
}
// Name returns the semantic convention name of the instrument.
func (DiskMerged) Name() string {
return "system.disk.merged"
}
// Unit returns the semantic convention unit of the instrument
func (DiskMerged) Unit() string {
return "{operation}"
}
// Description returns the semantic convention description of the instrument
func (DiskMerged) Description() string {
return "The number of disk reads/writes merged into single physical disk access operations."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
func (m DiskMerged) Add(
ctx context.Context,
incr int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64Counter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
func (m DiskMerged) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64Counter.Add(ctx, incr, *o...)
}
// AttrDiskIODirection returns an optional attribute for the "disk.io.direction"
// semantic convention. It represents the disk IO operation direction.
func (DiskMerged) AttrDiskIODirection(val DiskIODirectionAttr) attribute.KeyValue {
return attribute.String("disk.io.direction", string(val))
}
// AttrDevice returns an optional attribute for the "system.device" semantic
// convention. It represents the device identifier.
func (DiskMerged) AttrDevice(val string) attribute.KeyValue {
return attribute.String("system.device", val)
}
// DiskOperationTime is an instrument used to record metric values conforming to
// the "system.disk.operation_time" semantic conventions. It represents the sum
// of the time each operation took to complete.
type DiskOperationTime struct {
metric.Float64Counter
}
var newDiskOperationTimeOpts = []metric.Float64CounterOption{
metric.WithDescription("Sum of the time each operation took to complete."),
metric.WithUnit("s"),
}
// NewDiskOperationTime returns a new DiskOperationTime instrument.
func NewDiskOperationTime(
m metric.Meter,
opt ...metric.Float64CounterOption,
) (DiskOperationTime, error) {
// Check if the meter is nil.
if m == nil {
return DiskOperationTime{noop.Float64Counter{}}, nil
}
if len(opt) == 0 {
opt = newDiskOperationTimeOpts
} else {
opt = append(opt, newDiskOperationTimeOpts...)
}
i, err := m.Float64Counter(
"system.disk.operation_time",
opt...,
)
if err != nil {
return DiskOperationTime{noop.Float64Counter{}}, err
}
return DiskOperationTime{i}, nil
}
// Inst returns the underlying metric instrument.
func (m DiskOperationTime) Inst() metric.Float64Counter {
return m.Float64Counter
}
// Name returns the semantic convention name of the instrument.
func (DiskOperationTime) Name() string {
return "system.disk.operation_time"
}
// Unit returns the semantic convention unit of the instrument
func (DiskOperationTime) Unit() string {
return "s"
}
// Description returns the semantic convention description of the instrument
func (DiskOperationTime) Description() string {
return "Sum of the time each operation took to complete."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
//
// Because it is the sum of time each request took, parallel-issued requests each
// contribute to make the count grow. Measured as:
//
// - Linux: Fields 7 & 11 from [procfs-diskstats]
// - Windows: "Avg. Disk sec/Read" perf counter multiplied by "Disk Reads/sec"
// perf counter (similar for Writes)
//
//
// [procfs-diskstats]: https://www.kernel.org/doc/Documentation/ABI/testing/procfs-diskstats
func (m DiskOperationTime) Add(
ctx context.Context,
incr float64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Float64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Float64Counter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
//
// Because it is the sum of time each request took, parallel-issued requests each
// contribute to make the count grow. Measured as:
//
// - Linux: Fields 7 & 11 from [procfs-diskstats]
// - Windows: "Avg. Disk sec/Read" perf counter multiplied by "Disk Reads/sec"
// perf counter (similar for Writes)
//
//
// [procfs-diskstats]: https://www.kernel.org/doc/Documentation/ABI/testing/procfs-diskstats
func (m DiskOperationTime) AddSet(ctx context.Context, incr float64, set attribute.Set) {
if set.Len() == 0 {
m.Float64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Float64Counter.Add(ctx, incr, *o...)
}
// AttrDiskIODirection returns an optional attribute for the "disk.io.direction"
// semantic convention. It represents the disk IO operation direction.
func (DiskOperationTime) AttrDiskIODirection(val DiskIODirectionAttr) attribute.KeyValue {
return attribute.String("disk.io.direction", string(val))
}
// AttrDevice returns an optional attribute for the "system.device" semantic
// convention. It represents the device identifier.
func (DiskOperationTime) AttrDevice(val string) attribute.KeyValue {
return attribute.String("system.device", val)
}
// DiskOperations is an instrument used to record metric values conforming to the
// "system.disk.operations" semantic conventions. It represents the disk
// operations count.
type DiskOperations struct {
metric.Int64Counter
}
var newDiskOperationsOpts = []metric.Int64CounterOption{
metric.WithDescription("Disk operations count."),
metric.WithUnit("{operation}"),
}
// NewDiskOperations returns a new DiskOperations instrument.
func NewDiskOperations(
m metric.Meter,
opt ...metric.Int64CounterOption,
) (DiskOperations, error) {
// Check if the meter is nil.
if m == nil {
return DiskOperations{noop.Int64Counter{}}, nil
}
if len(opt) == 0 {
opt = newDiskOperationsOpts
} else {
opt = append(opt, newDiskOperationsOpts...)
}
i, err := m.Int64Counter(
"system.disk.operations",
opt...,
)
if err != nil {
return DiskOperations{noop.Int64Counter{}}, err
}
return DiskOperations{i}, nil
}
// Inst returns the underlying metric instrument.
func (m DiskOperations) Inst() metric.Int64Counter {
return m.Int64Counter
}
// Name returns the semantic convention name of the instrument.
func (DiskOperations) Name() string {
return "system.disk.operations"
}
// Unit returns the semantic convention unit of the instrument
func (DiskOperations) Unit() string {
return "{operation}"
}
// Description returns the semantic convention description of the instrument
func (DiskOperations) Description() string {
return "Disk operations count."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
func (m DiskOperations) Add(
ctx context.Context,
incr int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64Counter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
func (m DiskOperations) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64Counter.Add(ctx, incr, *o...)
}
// AttrDiskIODirection returns an optional attribute for the "disk.io.direction"
// semantic convention. It represents the disk IO operation direction.
func (DiskOperations) AttrDiskIODirection(val DiskIODirectionAttr) attribute.KeyValue {
return attribute.String("disk.io.direction", string(val))
}
// AttrDevice returns an optional attribute for the "system.device" semantic
// convention. It represents the device identifier.
func (DiskOperations) AttrDevice(val string) attribute.KeyValue {
return attribute.String("system.device", val)
}
// FilesystemLimit is an instrument used to record metric values conforming to
// the "system.filesystem.limit" semantic conventions. It represents the total
// storage capacity of the filesystem.
type FilesystemLimit struct {
metric.Int64UpDownCounter
}
var newFilesystemLimitOpts = []metric.Int64UpDownCounterOption{
metric.WithDescription("The total storage capacity of the filesystem."),
metric.WithUnit("By"),
}
// NewFilesystemLimit returns a new FilesystemLimit instrument.
func NewFilesystemLimit(
m metric.Meter,
opt ...metric.Int64UpDownCounterOption,
) (FilesystemLimit, error) {
// Check if the meter is nil.
if m == nil {
return FilesystemLimit{noop.Int64UpDownCounter{}}, nil
}
if len(opt) == 0 {
opt = newFilesystemLimitOpts
} else {
opt = append(opt, newFilesystemLimitOpts...)
}
i, err := m.Int64UpDownCounter(
"system.filesystem.limit",
opt...,
)
if err != nil {
return FilesystemLimit{noop.Int64UpDownCounter{}}, err
}
return FilesystemLimit{i}, nil
}
// Inst returns the underlying metric instrument.
func (m FilesystemLimit) Inst() metric.Int64UpDownCounter {
return m.Int64UpDownCounter
}
// Name returns the semantic convention name of the instrument.
func (FilesystemLimit) Name() string {
return "system.filesystem.limit"
}
// Unit returns the semantic convention unit of the instrument
func (FilesystemLimit) Unit() string {
return "By"
}
// Description returns the semantic convention description of the instrument
func (FilesystemLimit) Description() string {
return "The total storage capacity of the filesystem."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
func (m FilesystemLimit) Add(
ctx context.Context,
incr int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
func (m FilesystemLimit) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AttrDevice returns an optional attribute for the "system.device" semantic
// convention. It represents the identifier for the device where the filesystem
// resides.
func (FilesystemLimit) AttrDevice(val string) attribute.KeyValue {
return attribute.String("system.device", val)
}
// AttrFilesystemMode returns an optional attribute for the
// "system.filesystem.mode" semantic convention. It represents the filesystem
// mode.
func (FilesystemLimit) AttrFilesystemMode(val string) attribute.KeyValue {
return attribute.String("system.filesystem.mode", val)
}
// AttrFilesystemMountpoint returns an optional attribute for the
// "system.filesystem.mountpoint" semantic convention. It represents the
// filesystem mount path.
func (FilesystemLimit) AttrFilesystemMountpoint(val string) attribute.KeyValue {
return attribute.String("system.filesystem.mountpoint", val)
}
// AttrFilesystemType returns an optional attribute for the
// "system.filesystem.type" semantic convention. It represents the filesystem
// type.
func (FilesystemLimit) AttrFilesystemType(val FilesystemTypeAttr) attribute.KeyValue {
return attribute.String("system.filesystem.type", string(val))
}
// FilesystemUsage is an instrument used to record metric values conforming to
// the "system.filesystem.usage" semantic conventions. It represents the reports
// a filesystem's space usage across different states.
type FilesystemUsage struct {
metric.Int64UpDownCounter
}
var newFilesystemUsageOpts = []metric.Int64UpDownCounterOption{
metric.WithDescription("Reports a filesystem's space usage across different states."),
metric.WithUnit("By"),
}
// NewFilesystemUsage returns a new FilesystemUsage instrument.
func NewFilesystemUsage(
m metric.Meter,
opt ...metric.Int64UpDownCounterOption,
) (FilesystemUsage, error) {
// Check if the meter is nil.
if m == nil {
return FilesystemUsage{noop.Int64UpDownCounter{}}, nil
}
if len(opt) == 0 {
opt = newFilesystemUsageOpts
} else {
opt = append(opt, newFilesystemUsageOpts...)
}
i, err := m.Int64UpDownCounter(
"system.filesystem.usage",
opt...,
)
if err != nil {
return FilesystemUsage{noop.Int64UpDownCounter{}}, err
}
return FilesystemUsage{i}, nil
}
// Inst returns the underlying metric instrument.
func (m FilesystemUsage) Inst() metric.Int64UpDownCounter {
return m.Int64UpDownCounter
}
// Name returns the semantic convention name of the instrument.
func (FilesystemUsage) Name() string {
return "system.filesystem.usage"
}
// Unit returns the semantic convention unit of the instrument
func (FilesystemUsage) Unit() string {
return "By"
}
// Description returns the semantic convention description of the instrument
func (FilesystemUsage) Description() string {
return "Reports a filesystem's space usage across different states."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
//
// The sum of all `system.filesystem.usage` values over the different
// `system.filesystem.state` attributes
// SHOULD equal the total storage capacity of the filesystem, that is
// `system.filesystem.limit`.
func (m FilesystemUsage) Add(
ctx context.Context,
incr int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
//
// The sum of all `system.filesystem.usage` values over the different
// `system.filesystem.state` attributes
// SHOULD equal the total storage capacity of the filesystem, that is
// `system.filesystem.limit`.
func (m FilesystemUsage) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AttrDevice returns an optional attribute for the "system.device" semantic
// convention. It represents the identifier for the device where the filesystem
// resides.
func (FilesystemUsage) AttrDevice(val string) attribute.KeyValue {
return attribute.String("system.device", val)
}
// AttrFilesystemMode returns an optional attribute for the
// "system.filesystem.mode" semantic convention. It represents the filesystem
// mode.
func (FilesystemUsage) AttrFilesystemMode(val string) attribute.KeyValue {
return attribute.String("system.filesystem.mode", val)
}
// AttrFilesystemMountpoint returns an optional attribute for the
// "system.filesystem.mountpoint" semantic convention. It represents the
// filesystem mount path.
func (FilesystemUsage) AttrFilesystemMountpoint(val string) attribute.KeyValue {
return attribute.String("system.filesystem.mountpoint", val)
}
// AttrFilesystemState returns an optional attribute for the
// "system.filesystem.state" semantic convention. It represents the filesystem
// state.
func (FilesystemUsage) AttrFilesystemState(val FilesystemStateAttr) attribute.KeyValue {
return attribute.String("system.filesystem.state", string(val))
}
// AttrFilesystemType returns an optional attribute for the
// "system.filesystem.type" semantic convention. It represents the filesystem
// type.
func (FilesystemUsage) AttrFilesystemType(val FilesystemTypeAttr) attribute.KeyValue {
return attribute.String("system.filesystem.type", string(val))
}
// FilesystemUtilization is an instrument used to record metric values conforming
// to the "system.filesystem.utilization" semantic conventions. It represents the
// fraction of filesystem bytes used.
type FilesystemUtilization struct {
metric.Int64Gauge
}
var newFilesystemUtilizationOpts = []metric.Int64GaugeOption{
metric.WithDescription("Fraction of filesystem bytes used."),
metric.WithUnit("1"),
}
// NewFilesystemUtilization returns a new FilesystemUtilization instrument.
func NewFilesystemUtilization(
m metric.Meter,
opt ...metric.Int64GaugeOption,
) (FilesystemUtilization, error) {
// Check if the meter is nil.
if m == nil {
return FilesystemUtilization{noop.Int64Gauge{}}, nil
}
if len(opt) == 0 {
opt = newFilesystemUtilizationOpts
} else {
opt = append(opt, newFilesystemUtilizationOpts...)
}
i, err := m.Int64Gauge(
"system.filesystem.utilization",
opt...,
)
if err != nil {
return FilesystemUtilization{noop.Int64Gauge{}}, err
}
return FilesystemUtilization{i}, nil
}
// Inst returns the underlying metric instrument.
func (m FilesystemUtilization) Inst() metric.Int64Gauge {
return m.Int64Gauge
}
// Name returns the semantic convention name of the instrument.
func (FilesystemUtilization) Name() string {
return "system.filesystem.utilization"
}
// Unit returns the semantic convention unit of the instrument
func (FilesystemUtilization) Unit() string {
return "1"
}
// Description returns the semantic convention description of the instrument
func (FilesystemUtilization) Description() string {
return "Fraction of filesystem bytes used."
}
// Record records val to the current distribution for attrs.
//
// All additional attrs passed are included in the recorded value.
func (m FilesystemUtilization) Record(
ctx context.Context,
val int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64Gauge.Record(ctx, val)
return
}
o := recOptPool.Get().(*[]metric.RecordOption)
defer func() {
*o = (*o)[:0]
recOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64Gauge.Record(ctx, val, *o...)
}
// RecordSet records val to the current distribution for set.
func (m FilesystemUtilization) RecordSet(ctx context.Context, val int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64Gauge.Record(ctx, val)
return
}
o := recOptPool.Get().(*[]metric.RecordOption)
defer func() {
*o = (*o)[:0]
recOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64Gauge.Record(ctx, val, *o...)
}
// AttrDevice returns an optional attribute for the "system.device" semantic
// convention. It represents the identifier for the device where the filesystem
// resides.
func (FilesystemUtilization) AttrDevice(val string) attribute.KeyValue {
return attribute.String("system.device", val)
}
// AttrFilesystemMode returns an optional attribute for the
// "system.filesystem.mode" semantic convention. It represents the filesystem
// mode.
func (FilesystemUtilization) AttrFilesystemMode(val string) attribute.KeyValue {
return attribute.String("system.filesystem.mode", val)
}
// AttrFilesystemMountpoint returns an optional attribute for the
// "system.filesystem.mountpoint" semantic convention. It represents the
// filesystem mount path.
func (FilesystemUtilization) AttrFilesystemMountpoint(val string) attribute.KeyValue {
return attribute.String("system.filesystem.mountpoint", val)
}
// AttrFilesystemState returns an optional attribute for the
// "system.filesystem.state" semantic convention. It represents the filesystem
// state.
func (FilesystemUtilization) AttrFilesystemState(val FilesystemStateAttr) attribute.KeyValue {
return attribute.String("system.filesystem.state", string(val))
}
// AttrFilesystemType returns an optional attribute for the
// "system.filesystem.type" semantic convention. It represents the filesystem
// type.
func (FilesystemUtilization) AttrFilesystemType(val FilesystemTypeAttr) attribute.KeyValue {
return attribute.String("system.filesystem.type", string(val))
}
// MemoryLimit is an instrument used to record metric values conforming to the
// "system.memory.limit" semantic conventions. It represents the total virtual
// memory available in the system.
type MemoryLimit struct {
metric.Int64UpDownCounter
}
var newMemoryLimitOpts = []metric.Int64UpDownCounterOption{
metric.WithDescription("Total virtual memory available in the system."),
metric.WithUnit("By"),
}
// NewMemoryLimit returns a new MemoryLimit instrument.
func NewMemoryLimit(
m metric.Meter,
opt ...metric.Int64UpDownCounterOption,
) (MemoryLimit, error) {
// Check if the meter is nil.
if m == nil {
return MemoryLimit{noop.Int64UpDownCounter{}}, nil
}
if len(opt) == 0 {
opt = newMemoryLimitOpts
} else {
opt = append(opt, newMemoryLimitOpts...)
}
i, err := m.Int64UpDownCounter(
"system.memory.limit",
opt...,
)
if err != nil {
return MemoryLimit{noop.Int64UpDownCounter{}}, err
}
return MemoryLimit{i}, nil
}
// Inst returns the underlying metric instrument.
func (m MemoryLimit) Inst() metric.Int64UpDownCounter {
return m.Int64UpDownCounter
}
// Name returns the semantic convention name of the instrument.
func (MemoryLimit) Name() string {
return "system.memory.limit"
}
// Unit returns the semantic convention unit of the instrument
func (MemoryLimit) Unit() string {
return "By"
}
// Description returns the semantic convention description of the instrument
func (MemoryLimit) Description() string {
return "Total virtual memory available in the system."
}
// Add adds incr to the existing count for attrs.
func (m MemoryLimit) Add(ctx context.Context, incr int64, attrs ...attribute.KeyValue) {
if len(attrs) == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributes(attrs...))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
func (m MemoryLimit) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// MemoryLinuxAvailable is an instrument used to record metric values conforming
// to the "system.memory.linux.available" semantic conventions. It represents an
// estimate of how much memory is available for starting new applications,
// without causing swapping.
type MemoryLinuxAvailable struct {
metric.Int64UpDownCounter
}
var newMemoryLinuxAvailableOpts = []metric.Int64UpDownCounterOption{
metric.WithDescription("An estimate of how much memory is available for starting new applications, without causing swapping."),
metric.WithUnit("By"),
}
// NewMemoryLinuxAvailable returns a new MemoryLinuxAvailable instrument.
func NewMemoryLinuxAvailable(
m metric.Meter,
opt ...metric.Int64UpDownCounterOption,
) (MemoryLinuxAvailable, error) {
// Check if the meter is nil.
if m == nil {
return MemoryLinuxAvailable{noop.Int64UpDownCounter{}}, nil
}
if len(opt) == 0 {
opt = newMemoryLinuxAvailableOpts
} else {
opt = append(opt, newMemoryLinuxAvailableOpts...)
}
i, err := m.Int64UpDownCounter(
"system.memory.linux.available",
opt...,
)
if err != nil {
return MemoryLinuxAvailable{noop.Int64UpDownCounter{}}, err
}
return MemoryLinuxAvailable{i}, nil
}
// Inst returns the underlying metric instrument.
func (m MemoryLinuxAvailable) Inst() metric.Int64UpDownCounter {
return m.Int64UpDownCounter
}
// Name returns the semantic convention name of the instrument.
func (MemoryLinuxAvailable) Name() string {
return "system.memory.linux.available"
}
// Unit returns the semantic convention unit of the instrument
func (MemoryLinuxAvailable) Unit() string {
return "By"
}
// Description returns the semantic convention description of the instrument
func (MemoryLinuxAvailable) Description() string {
return "An estimate of how much memory is available for starting new applications, without causing swapping."
}
// Add adds incr to the existing count for attrs.
//
// This is an alternative to `system.memory.usage` metric with `state=free`.
// Linux starting from 3.14 exports "available" memory. It takes "free" memory as
// a baseline, and then factors in kernel-specific values.
// This is supposed to be more accurate than just "free" memory.
// For reference, see the calculations [here].
// See also `MemAvailable` in [/proc/meminfo].
//
// [here]: https://superuser.com/a/980821
// [/proc/meminfo]: https://man7.org/linux/man-pages/man5/proc.5.html
func (m MemoryLinuxAvailable) Add(ctx context.Context, incr int64, attrs ...attribute.KeyValue) {
if len(attrs) == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributes(attrs...))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
//
// This is an alternative to `system.memory.usage` metric with `state=free`.
// Linux starting from 3.14 exports "available" memory. It takes "free" memory as
// a baseline, and then factors in kernel-specific values.
// This is supposed to be more accurate than just "free" memory.
// For reference, see the calculations [here].
// See also `MemAvailable` in [/proc/meminfo].
//
// [here]: https://superuser.com/a/980821
// [/proc/meminfo]: https://man7.org/linux/man-pages/man5/proc.5.html
func (m MemoryLinuxAvailable) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// MemoryLinuxShared is an instrument used to record metric values conforming to
// the "system.memory.linux.shared" semantic conventions. It represents the
// shared memory used (mostly by tmpfs).
type MemoryLinuxShared struct {
metric.Int64UpDownCounter
}
var newMemoryLinuxSharedOpts = []metric.Int64UpDownCounterOption{
metric.WithDescription("Shared memory used (mostly by tmpfs)."),
metric.WithUnit("By"),
}
// NewMemoryLinuxShared returns a new MemoryLinuxShared instrument.
func NewMemoryLinuxShared(
m metric.Meter,
opt ...metric.Int64UpDownCounterOption,
) (MemoryLinuxShared, error) {
// Check if the meter is nil.
if m == nil {
return MemoryLinuxShared{noop.Int64UpDownCounter{}}, nil
}
if len(opt) == 0 {
opt = newMemoryLinuxSharedOpts
} else {
opt = append(opt, newMemoryLinuxSharedOpts...)
}
i, err := m.Int64UpDownCounter(
"system.memory.linux.shared",
opt...,
)
if err != nil {
return MemoryLinuxShared{noop.Int64UpDownCounter{}}, err
}
return MemoryLinuxShared{i}, nil
}
// Inst returns the underlying metric instrument.
func (m MemoryLinuxShared) Inst() metric.Int64UpDownCounter {
return m.Int64UpDownCounter
}
// Name returns the semantic convention name of the instrument.
func (MemoryLinuxShared) Name() string {
return "system.memory.linux.shared"
}
// Unit returns the semantic convention unit of the instrument
func (MemoryLinuxShared) Unit() string {
return "By"
}
// Description returns the semantic convention description of the instrument
func (MemoryLinuxShared) Description() string {
return "Shared memory used (mostly by tmpfs)."
}
// Add adds incr to the existing count for attrs.
//
// Equivalent of `shared` from [`free` command] or
// `Shmem` from [`/proc/meminfo`]"
//
// [`free` command]: https://man7.org/linux/man-pages/man1/free.1.html
// [`/proc/meminfo`]: https://man7.org/linux/man-pages/man5/proc.5.html
func (m MemoryLinuxShared) Add(ctx context.Context, incr int64, attrs ...attribute.KeyValue) {
if len(attrs) == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributes(attrs...))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
//
// Equivalent of `shared` from [`free` command] or
// `Shmem` from [`/proc/meminfo`]"
//
// [`free` command]: https://man7.org/linux/man-pages/man1/free.1.html
// [`/proc/meminfo`]: https://man7.org/linux/man-pages/man5/proc.5.html
func (m MemoryLinuxShared) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// MemoryLinuxSlabUsage is an instrument used to record metric values conforming
// to the "system.memory.linux.slab.usage" semantic conventions. It represents
// the reports the memory used by the Linux kernel for managing caches of
// frequently used objects.
type MemoryLinuxSlabUsage struct {
metric.Int64UpDownCounter
}
var newMemoryLinuxSlabUsageOpts = []metric.Int64UpDownCounterOption{
metric.WithDescription("Reports the memory used by the Linux kernel for managing caches of frequently used objects."),
metric.WithUnit("By"),
}
// NewMemoryLinuxSlabUsage returns a new MemoryLinuxSlabUsage instrument.
func NewMemoryLinuxSlabUsage(
m metric.Meter,
opt ...metric.Int64UpDownCounterOption,
) (MemoryLinuxSlabUsage, error) {
// Check if the meter is nil.
if m == nil {
return MemoryLinuxSlabUsage{noop.Int64UpDownCounter{}}, nil
}
if len(opt) == 0 {
opt = newMemoryLinuxSlabUsageOpts
} else {
opt = append(opt, newMemoryLinuxSlabUsageOpts...)
}
i, err := m.Int64UpDownCounter(
"system.memory.linux.slab.usage",
opt...,
)
if err != nil {
return MemoryLinuxSlabUsage{noop.Int64UpDownCounter{}}, err
}
return MemoryLinuxSlabUsage{i}, nil
}
// Inst returns the underlying metric instrument.
func (m MemoryLinuxSlabUsage) Inst() metric.Int64UpDownCounter {
return m.Int64UpDownCounter
}
// Name returns the semantic convention name of the instrument.
func (MemoryLinuxSlabUsage) Name() string {
return "system.memory.linux.slab.usage"
}
// Unit returns the semantic convention unit of the instrument
func (MemoryLinuxSlabUsage) Unit() string {
return "By"
}
// Description returns the semantic convention description of the instrument
func (MemoryLinuxSlabUsage) Description() string {
return "Reports the memory used by the Linux kernel for managing caches of frequently used objects."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
//
// The sum over the `reclaimable` and `unreclaimable` state values in
// `memory.linux.slab.usage` SHOULD be equal to the total slab memory available
// on the system.
// Note that the total slab memory is not constant and may vary over time.
// See also the [Slab allocator] and `Slab` in [/proc/meminfo].
//
// [Slab allocator]: https://blogs.oracle.com/linux/post/understanding-linux-kernel-memory-statistics
// [/proc/meminfo]: https://man7.org/linux/man-pages/man5/proc.5.html
func (m MemoryLinuxSlabUsage) Add(
ctx context.Context,
incr int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
//
// The sum over the `reclaimable` and `unreclaimable` state values in
// `memory.linux.slab.usage` SHOULD be equal to the total slab memory available
// on the system.
// Note that the total slab memory is not constant and may vary over time.
// See also the [Slab allocator] and `Slab` in [/proc/meminfo].
//
// [Slab allocator]: https://blogs.oracle.com/linux/post/understanding-linux-kernel-memory-statistics
// [/proc/meminfo]: https://man7.org/linux/man-pages/man5/proc.5.html
func (m MemoryLinuxSlabUsage) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AttrMemoryLinuxSlabState returns an optional attribute for the
// "system.memory.linux.slab.state" semantic convention. It represents the Linux
// Slab memory state.
func (MemoryLinuxSlabUsage) AttrMemoryLinuxSlabState(val MemoryLinuxSlabStateAttr) attribute.KeyValue {
return attribute.String("system.memory.linux.slab.state", string(val))
}
// MemoryUsage is an instrument used to record metric values conforming to the
// "system.memory.usage" semantic conventions. It represents the reports memory
// in use by state.
type MemoryUsage struct {
metric.Int64ObservableUpDownCounter
}
var newMemoryUsageOpts = []metric.Int64ObservableUpDownCounterOption{
metric.WithDescription("Reports memory in use by state."),
metric.WithUnit("By"),
}
// NewMemoryUsage returns a new MemoryUsage instrument.
func NewMemoryUsage(
m metric.Meter,
opt ...metric.Int64ObservableUpDownCounterOption,
) (MemoryUsage, error) {
// Check if the meter is nil.
if m == nil {
return MemoryUsage{noop.Int64ObservableUpDownCounter{}}, nil
}
if len(opt) == 0 {
opt = newMemoryUsageOpts
} else {
opt = append(opt, newMemoryUsageOpts...)
}
i, err := m.Int64ObservableUpDownCounter(
"system.memory.usage",
opt...,
)
if err != nil {
return MemoryUsage{noop.Int64ObservableUpDownCounter{}}, err
}
return MemoryUsage{i}, nil
}
// Inst returns the underlying metric instrument.
func (m MemoryUsage) Inst() metric.Int64ObservableUpDownCounter {
return m.Int64ObservableUpDownCounter
}
// Name returns the semantic convention name of the instrument.
func (MemoryUsage) Name() string {
return "system.memory.usage"
}
// Unit returns the semantic convention unit of the instrument
func (MemoryUsage) Unit() string {
return "By"
}
// Description returns the semantic convention description of the instrument
func (MemoryUsage) Description() string {
return "Reports memory in use by state."
}
// AttrMemoryState returns an optional attribute for the "system.memory.state"
// semantic convention. It represents the memory state.
func (MemoryUsage) AttrMemoryState(val MemoryStateAttr) attribute.KeyValue {
return attribute.String("system.memory.state", string(val))
}
// MemoryUtilization is an instrument used to record metric values conforming to
// the "system.memory.utilization" semantic conventions. It represents the
// percentage of memory bytes in use.
type MemoryUtilization struct {
metric.Float64ObservableGauge
}
var newMemoryUtilizationOpts = []metric.Float64ObservableGaugeOption{
metric.WithDescription("Percentage of memory bytes in use."),
metric.WithUnit("1"),
}
// NewMemoryUtilization returns a new MemoryUtilization instrument.
func NewMemoryUtilization(
m metric.Meter,
opt ...metric.Float64ObservableGaugeOption,
) (MemoryUtilization, error) {
// Check if the meter is nil.
if m == nil {
return MemoryUtilization{noop.Float64ObservableGauge{}}, nil
}
if len(opt) == 0 {
opt = newMemoryUtilizationOpts
} else {
opt = append(opt, newMemoryUtilizationOpts...)
}
i, err := m.Float64ObservableGauge(
"system.memory.utilization",
opt...,
)
if err != nil {
return MemoryUtilization{noop.Float64ObservableGauge{}}, err
}
return MemoryUtilization{i}, nil
}
// Inst returns the underlying metric instrument.
func (m MemoryUtilization) Inst() metric.Float64ObservableGauge {
return m.Float64ObservableGauge
}
// Name returns the semantic convention name of the instrument.
func (MemoryUtilization) Name() string {
return "system.memory.utilization"
}
// Unit returns the semantic convention unit of the instrument
func (MemoryUtilization) Unit() string {
return "1"
}
// Description returns the semantic convention description of the instrument
func (MemoryUtilization) Description() string {
return "Percentage of memory bytes in use."
}
// AttrMemoryState returns an optional attribute for the "system.memory.state"
// semantic convention. It represents the memory state.
func (MemoryUtilization) AttrMemoryState(val MemoryStateAttr) attribute.KeyValue {
return attribute.String("system.memory.state", string(val))
}
// NetworkConnectionCount is an instrument used to record metric values
// conforming to the "system.network.connection.count" semantic conventions. It
// represents the number of connections.
type NetworkConnectionCount struct {
metric.Int64UpDownCounter
}
var newNetworkConnectionCountOpts = []metric.Int64UpDownCounterOption{
metric.WithDescription("The number of connections."),
metric.WithUnit("{connection}"),
}
// NewNetworkConnectionCount returns a new NetworkConnectionCount instrument.
func NewNetworkConnectionCount(
m metric.Meter,
opt ...metric.Int64UpDownCounterOption,
) (NetworkConnectionCount, error) {
// Check if the meter is nil.
if m == nil {
return NetworkConnectionCount{noop.Int64UpDownCounter{}}, nil
}
if len(opt) == 0 {
opt = newNetworkConnectionCountOpts
} else {
opt = append(opt, newNetworkConnectionCountOpts...)
}
i, err := m.Int64UpDownCounter(
"system.network.connection.count",
opt...,
)
if err != nil {
return NetworkConnectionCount{noop.Int64UpDownCounter{}}, err
}
return NetworkConnectionCount{i}, nil
}
// Inst returns the underlying metric instrument.
func (m NetworkConnectionCount) Inst() metric.Int64UpDownCounter {
return m.Int64UpDownCounter
}
// Name returns the semantic convention name of the instrument.
func (NetworkConnectionCount) Name() string {
return "system.network.connection.count"
}
// Unit returns the semantic convention unit of the instrument
func (NetworkConnectionCount) Unit() string {
return "{connection}"
}
// Description returns the semantic convention description of the instrument
func (NetworkConnectionCount) Description() string {
return "The number of connections."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
func (m NetworkConnectionCount) Add(
ctx context.Context,
incr int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
func (m NetworkConnectionCount) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AttrNetworkConnectionState returns an optional attribute for the
// "network.connection.state" semantic convention. It represents the state of
// network connection.
func (NetworkConnectionCount) AttrNetworkConnectionState(val NetworkConnectionStateAttr) attribute.KeyValue {
return attribute.String("network.connection.state", string(val))
}
// AttrNetworkInterfaceName returns an optional attribute for the
// "network.interface.name" semantic convention. It represents the network
// interface name.
func (NetworkConnectionCount) AttrNetworkInterfaceName(val string) attribute.KeyValue {
return attribute.String("network.interface.name", val)
}
// AttrNetworkTransport returns an optional attribute for the "network.transport"
// semantic convention. It represents the [OSI transport layer] or
// [inter-process communication method].
//
// [OSI transport layer]: https://wikipedia.org/wiki/Transport_layer
// [inter-process communication method]: https://wikipedia.org/wiki/Inter-process_communication
func (NetworkConnectionCount) AttrNetworkTransport(val NetworkTransportAttr) attribute.KeyValue {
return attribute.String("network.transport", string(val))
}
// NetworkErrors is an instrument used to record metric values conforming to the
// "system.network.errors" semantic conventions. It represents the count of
// network errors detected.
type NetworkErrors struct {
metric.Int64Counter
}
var newNetworkErrorsOpts = []metric.Int64CounterOption{
metric.WithDescription("Count of network errors detected."),
metric.WithUnit("{error}"),
}
// NewNetworkErrors returns a new NetworkErrors instrument.
func NewNetworkErrors(
m metric.Meter,
opt ...metric.Int64CounterOption,
) (NetworkErrors, error) {
// Check if the meter is nil.
if m == nil {
return NetworkErrors{noop.Int64Counter{}}, nil
}
if len(opt) == 0 {
opt = newNetworkErrorsOpts
} else {
opt = append(opt, newNetworkErrorsOpts...)
}
i, err := m.Int64Counter(
"system.network.errors",
opt...,
)
if err != nil {
return NetworkErrors{noop.Int64Counter{}}, err
}
return NetworkErrors{i}, nil
}
// Inst returns the underlying metric instrument.
func (m NetworkErrors) Inst() metric.Int64Counter {
return m.Int64Counter
}
// Name returns the semantic convention name of the instrument.
func (NetworkErrors) Name() string {
return "system.network.errors"
}
// Unit returns the semantic convention unit of the instrument
func (NetworkErrors) Unit() string {
return "{error}"
}
// Description returns the semantic convention description of the instrument
func (NetworkErrors) Description() string {
return "Count of network errors detected."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
//
// Measured as:
//
// - Linux: the `errs` column in `/proc/net/dev` ([source]).
// - Windows: [`InErrors`/`OutErrors`]
// from [`GetIfEntry2`].
//
//
// [source]: https://web.archive.org/web/20180321091318/http://www.onlamp.com/pub/a/linux/2000/11/16/LinuxAdmin.html
// [`InErrors`/`OutErrors`]: https://docs.microsoft.com/windows/win32/api/netioapi/ns-netioapi-mib_if_row2
// [`GetIfEntry2`]: https://docs.microsoft.com/windows/win32/api/netioapi/nf-netioapi-getifentry2
func (m NetworkErrors) Add(
ctx context.Context,
incr int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64Counter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
//
// Measured as:
//
// - Linux: the `errs` column in `/proc/net/dev` ([source]).
// - Windows: [`InErrors`/`OutErrors`]
// from [`GetIfEntry2`].
//
//
// [source]: https://web.archive.org/web/20180321091318/http://www.onlamp.com/pub/a/linux/2000/11/16/LinuxAdmin.html
// [`InErrors`/`OutErrors`]: https://docs.microsoft.com/windows/win32/api/netioapi/ns-netioapi-mib_if_row2
// [`GetIfEntry2`]: https://docs.microsoft.com/windows/win32/api/netioapi/nf-netioapi-getifentry2
func (m NetworkErrors) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64Counter.Add(ctx, incr, *o...)
}
// AttrNetworkInterfaceName returns an optional attribute for the
// "network.interface.name" semantic convention. It represents the network
// interface name.
func (NetworkErrors) AttrNetworkInterfaceName(val string) attribute.KeyValue {
return attribute.String("network.interface.name", val)
}
// AttrNetworkIODirection returns an optional attribute for the
// "network.io.direction" semantic convention. It represents the network IO
// operation direction.
func (NetworkErrors) AttrNetworkIODirection(val NetworkIODirectionAttr) attribute.KeyValue {
return attribute.String("network.io.direction", string(val))
}
// NetworkIO is an instrument used to record metric values conforming to the
// "system.network.io" semantic conventions. It represents the number of bytes
// transmitted and received.
type NetworkIO struct {
metric.Int64ObservableCounter
}
var newNetworkIOOpts = []metric.Int64ObservableCounterOption{
metric.WithDescription("The number of bytes transmitted and received."),
metric.WithUnit("By"),
}
// NewNetworkIO returns a new NetworkIO instrument.
func NewNetworkIO(
m metric.Meter,
opt ...metric.Int64ObservableCounterOption,
) (NetworkIO, error) {
// Check if the meter is nil.
if m == nil {
return NetworkIO{noop.Int64ObservableCounter{}}, nil
}
if len(opt) == 0 {
opt = newNetworkIOOpts
} else {
opt = append(opt, newNetworkIOOpts...)
}
i, err := m.Int64ObservableCounter(
"system.network.io",
opt...,
)
if err != nil {
return NetworkIO{noop.Int64ObservableCounter{}}, err
}
return NetworkIO{i}, nil
}
// Inst returns the underlying metric instrument.
func (m NetworkIO) Inst() metric.Int64ObservableCounter {
return m.Int64ObservableCounter
}
// Name returns the semantic convention name of the instrument.
func (NetworkIO) Name() string {
return "system.network.io"
}
// Unit returns the semantic convention unit of the instrument
func (NetworkIO) Unit() string {
return "By"
}
// Description returns the semantic convention description of the instrument
func (NetworkIO) Description() string {
return "The number of bytes transmitted and received."
}
// AttrNetworkInterfaceName returns an optional attribute for the
// "network.interface.name" semantic convention. It represents the network
// interface name.
func (NetworkIO) AttrNetworkInterfaceName(val string) attribute.KeyValue {
return attribute.String("network.interface.name", val)
}
// AttrNetworkIODirection returns an optional attribute for the
// "network.io.direction" semantic convention. It represents the network IO
// operation direction.
func (NetworkIO) AttrNetworkIODirection(val NetworkIODirectionAttr) attribute.KeyValue {
return attribute.String("network.io.direction", string(val))
}
// NetworkPacketCount is an instrument used to record metric values conforming to
// the "system.network.packet.count" semantic conventions. It represents the
// number of packets transferred.
type NetworkPacketCount struct {
metric.Int64Counter
}
var newNetworkPacketCountOpts = []metric.Int64CounterOption{
metric.WithDescription("The number of packets transferred."),
metric.WithUnit("{packet}"),
}
// NewNetworkPacketCount returns a new NetworkPacketCount instrument.
func NewNetworkPacketCount(
m metric.Meter,
opt ...metric.Int64CounterOption,
) (NetworkPacketCount, error) {
// Check if the meter is nil.
if m == nil {
return NetworkPacketCount{noop.Int64Counter{}}, nil
}
if len(opt) == 0 {
opt = newNetworkPacketCountOpts
} else {
opt = append(opt, newNetworkPacketCountOpts...)
}
i, err := m.Int64Counter(
"system.network.packet.count",
opt...,
)
if err != nil {
return NetworkPacketCount{noop.Int64Counter{}}, err
}
return NetworkPacketCount{i}, nil
}
// Inst returns the underlying metric instrument.
func (m NetworkPacketCount) Inst() metric.Int64Counter {
return m.Int64Counter
}
// Name returns the semantic convention name of the instrument.
func (NetworkPacketCount) Name() string {
return "system.network.packet.count"
}
// Unit returns the semantic convention unit of the instrument
func (NetworkPacketCount) Unit() string {
return "{packet}"
}
// Description returns the semantic convention description of the instrument
func (NetworkPacketCount) Description() string {
return "The number of packets transferred."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
func (m NetworkPacketCount) Add(
ctx context.Context,
incr int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64Counter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
func (m NetworkPacketCount) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64Counter.Add(ctx, incr, *o...)
}
// AttrNetworkIODirection returns an optional attribute for the
// "network.io.direction" semantic convention. It represents the network IO
// operation direction.
func (NetworkPacketCount) AttrNetworkIODirection(val NetworkIODirectionAttr) attribute.KeyValue {
return attribute.String("network.io.direction", string(val))
}
// AttrDevice returns an optional attribute for the "system.device" semantic
// convention. It represents the device identifier.
func (NetworkPacketCount) AttrDevice(val string) attribute.KeyValue {
return attribute.String("system.device", val)
}
// NetworkPacketDropped is an instrument used to record metric values conforming
// to the "system.network.packet.dropped" semantic conventions. It represents the
// count of packets that are dropped or discarded even though there was no error.
type NetworkPacketDropped struct {
metric.Int64Counter
}
var newNetworkPacketDroppedOpts = []metric.Int64CounterOption{
metric.WithDescription("Count of packets that are dropped or discarded even though there was no error."),
metric.WithUnit("{packet}"),
}
// NewNetworkPacketDropped returns a new NetworkPacketDropped instrument.
func NewNetworkPacketDropped(
m metric.Meter,
opt ...metric.Int64CounterOption,
) (NetworkPacketDropped, error) {
// Check if the meter is nil.
if m == nil {
return NetworkPacketDropped{noop.Int64Counter{}}, nil
}
if len(opt) == 0 {
opt = newNetworkPacketDroppedOpts
} else {
opt = append(opt, newNetworkPacketDroppedOpts...)
}
i, err := m.Int64Counter(
"system.network.packet.dropped",
opt...,
)
if err != nil {
return NetworkPacketDropped{noop.Int64Counter{}}, err
}
return NetworkPacketDropped{i}, nil
}
// Inst returns the underlying metric instrument.
func (m NetworkPacketDropped) Inst() metric.Int64Counter {
return m.Int64Counter
}
// Name returns the semantic convention name of the instrument.
func (NetworkPacketDropped) Name() string {
return "system.network.packet.dropped"
}
// Unit returns the semantic convention unit of the instrument
func (NetworkPacketDropped) Unit() string {
return "{packet}"
}
// Description returns the semantic convention description of the instrument
func (NetworkPacketDropped) Description() string {
return "Count of packets that are dropped or discarded even though there was no error."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
//
// Measured as:
//
// - Linux: the `drop` column in `/proc/net/dev` ([source])
// - Windows: [`InDiscards`/`OutDiscards`]
// from [`GetIfEntry2`]
//
//
// [source]: https://web.archive.org/web/20180321091318/http://www.onlamp.com/pub/a/linux/2000/11/16/LinuxAdmin.html
// [`InDiscards`/`OutDiscards`]: https://docs.microsoft.com/windows/win32/api/netioapi/ns-netioapi-mib_if_row2
// [`GetIfEntry2`]: https://docs.microsoft.com/windows/win32/api/netioapi/nf-netioapi-getifentry2
func (m NetworkPacketDropped) Add(
ctx context.Context,
incr int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64Counter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
//
// Measured as:
//
// - Linux: the `drop` column in `/proc/net/dev` ([source])
// - Windows: [`InDiscards`/`OutDiscards`]
// from [`GetIfEntry2`]
//
//
// [source]: https://web.archive.org/web/20180321091318/http://www.onlamp.com/pub/a/linux/2000/11/16/LinuxAdmin.html
// [`InDiscards`/`OutDiscards`]: https://docs.microsoft.com/windows/win32/api/netioapi/ns-netioapi-mib_if_row2
// [`GetIfEntry2`]: https://docs.microsoft.com/windows/win32/api/netioapi/nf-netioapi-getifentry2
func (m NetworkPacketDropped) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64Counter.Add(ctx, incr, *o...)
}
// AttrNetworkInterfaceName returns an optional attribute for the
// "network.interface.name" semantic convention. It represents the network
// interface name.
func (NetworkPacketDropped) AttrNetworkInterfaceName(val string) attribute.KeyValue {
return attribute.String("network.interface.name", val)
}
// AttrNetworkIODirection returns an optional attribute for the
// "network.io.direction" semantic convention. It represents the network IO
// operation direction.
func (NetworkPacketDropped) AttrNetworkIODirection(val NetworkIODirectionAttr) attribute.KeyValue {
return attribute.String("network.io.direction", string(val))
}
// PagingFaults is an instrument used to record metric values conforming to the
// "system.paging.faults" semantic conventions. It represents the number of page
// faults.
type PagingFaults struct {
metric.Int64Counter
}
var newPagingFaultsOpts = []metric.Int64CounterOption{
metric.WithDescription("The number of page faults."),
metric.WithUnit("{fault}"),
}
// NewPagingFaults returns a new PagingFaults instrument.
func NewPagingFaults(
m metric.Meter,
opt ...metric.Int64CounterOption,
) (PagingFaults, error) {
// Check if the meter is nil.
if m == nil {
return PagingFaults{noop.Int64Counter{}}, nil
}
if len(opt) == 0 {
opt = newPagingFaultsOpts
} else {
opt = append(opt, newPagingFaultsOpts...)
}
i, err := m.Int64Counter(
"system.paging.faults",
opt...,
)
if err != nil {
return PagingFaults{noop.Int64Counter{}}, err
}
return PagingFaults{i}, nil
}
// Inst returns the underlying metric instrument.
func (m PagingFaults) Inst() metric.Int64Counter {
return m.Int64Counter
}
// Name returns the semantic convention name of the instrument.
func (PagingFaults) Name() string {
return "system.paging.faults"
}
// Unit returns the semantic convention unit of the instrument
func (PagingFaults) Unit() string {
return "{fault}"
}
// Description returns the semantic convention description of the instrument
func (PagingFaults) Description() string {
return "The number of page faults."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
func (m PagingFaults) Add(
ctx context.Context,
incr int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64Counter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
func (m PagingFaults) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64Counter.Add(ctx, incr, *o...)
}
// AttrPagingFaultType returns an optional attribute for the
// "system.paging.fault.type" semantic convention. It represents the paging fault
// type.
func (PagingFaults) AttrPagingFaultType(val PagingFaultTypeAttr) attribute.KeyValue {
return attribute.String("system.paging.fault.type", string(val))
}
// PagingOperations is an instrument used to record metric values conforming to
// the "system.paging.operations" semantic conventions. It represents the number
// of paging operations.
type PagingOperations struct {
metric.Int64Counter
}
var newPagingOperationsOpts = []metric.Int64CounterOption{
metric.WithDescription("The number of paging operations."),
metric.WithUnit("{operation}"),
}
// NewPagingOperations returns a new PagingOperations instrument.
func NewPagingOperations(
m metric.Meter,
opt ...metric.Int64CounterOption,
) (PagingOperations, error) {
// Check if the meter is nil.
if m == nil {
return PagingOperations{noop.Int64Counter{}}, nil
}
if len(opt) == 0 {
opt = newPagingOperationsOpts
} else {
opt = append(opt, newPagingOperationsOpts...)
}
i, err := m.Int64Counter(
"system.paging.operations",
opt...,
)
if err != nil {
return PagingOperations{noop.Int64Counter{}}, err
}
return PagingOperations{i}, nil
}
// Inst returns the underlying metric instrument.
func (m PagingOperations) Inst() metric.Int64Counter {
return m.Int64Counter
}
// Name returns the semantic convention name of the instrument.
func (PagingOperations) Name() string {
return "system.paging.operations"
}
// Unit returns the semantic convention unit of the instrument
func (PagingOperations) Unit() string {
return "{operation}"
}
// Description returns the semantic convention description of the instrument
func (PagingOperations) Description() string {
return "The number of paging operations."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
func (m PagingOperations) Add(
ctx context.Context,
incr int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64Counter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
func (m PagingOperations) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64Counter.Add(ctx, incr, *o...)
}
// AttrPagingDirection returns an optional attribute for the
// "system.paging.direction" semantic convention. It represents the paging access
// direction.
func (PagingOperations) AttrPagingDirection(val PagingDirectionAttr) attribute.KeyValue {
return attribute.String("system.paging.direction", string(val))
}
// AttrPagingFaultType returns an optional attribute for the
// "system.paging.fault.type" semantic convention. It represents the paging fault
// type.
func (PagingOperations) AttrPagingFaultType(val PagingFaultTypeAttr) attribute.KeyValue {
return attribute.String("system.paging.fault.type", string(val))
}
// PagingUsage is an instrument used to record metric values conforming to the
// "system.paging.usage" semantic conventions. It represents the unix swap or
// windows pagefile usage.
type PagingUsage struct {
metric.Int64UpDownCounter
}
var newPagingUsageOpts = []metric.Int64UpDownCounterOption{
metric.WithDescription("Unix swap or windows pagefile usage."),
metric.WithUnit("By"),
}
// NewPagingUsage returns a new PagingUsage instrument.
func NewPagingUsage(
m metric.Meter,
opt ...metric.Int64UpDownCounterOption,
) (PagingUsage, error) {
// Check if the meter is nil.
if m == nil {
return PagingUsage{noop.Int64UpDownCounter{}}, nil
}
if len(opt) == 0 {
opt = newPagingUsageOpts
} else {
opt = append(opt, newPagingUsageOpts...)
}
i, err := m.Int64UpDownCounter(
"system.paging.usage",
opt...,
)
if err != nil {
return PagingUsage{noop.Int64UpDownCounter{}}, err
}
return PagingUsage{i}, nil
}
// Inst returns the underlying metric instrument.
func (m PagingUsage) Inst() metric.Int64UpDownCounter {
return m.Int64UpDownCounter
}
// Name returns the semantic convention name of the instrument.
func (PagingUsage) Name() string {
return "system.paging.usage"
}
// Unit returns the semantic convention unit of the instrument
func (PagingUsage) Unit() string {
return "By"
}
// Description returns the semantic convention description of the instrument
func (PagingUsage) Description() string {
return "Unix swap or windows pagefile usage."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
func (m PagingUsage) Add(
ctx context.Context,
incr int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
func (m PagingUsage) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AttrDevice returns an optional attribute for the "system.device" semantic
// convention. It represents the unique identifier for the device responsible for
// managing paging operations.
func (PagingUsage) AttrDevice(val string) attribute.KeyValue {
return attribute.String("system.device", val)
}
// AttrPagingState returns an optional attribute for the "system.paging.state"
// semantic convention. It represents the memory paging state.
func (PagingUsage) AttrPagingState(val PagingStateAttr) attribute.KeyValue {
return attribute.String("system.paging.state", string(val))
}
// PagingUtilization is an instrument used to record metric values conforming to
// the "system.paging.utilization" semantic conventions. It represents the swap
// (unix) or pagefile (windows) utilization.
type PagingUtilization struct {
metric.Int64Gauge
}
var newPagingUtilizationOpts = []metric.Int64GaugeOption{
metric.WithDescription("Swap (unix) or pagefile (windows) utilization."),
metric.WithUnit("1"),
}
// NewPagingUtilization returns a new PagingUtilization instrument.
func NewPagingUtilization(
m metric.Meter,
opt ...metric.Int64GaugeOption,
) (PagingUtilization, error) {
// Check if the meter is nil.
if m == nil {
return PagingUtilization{noop.Int64Gauge{}}, nil
}
if len(opt) == 0 {
opt = newPagingUtilizationOpts
} else {
opt = append(opt, newPagingUtilizationOpts...)
}
i, err := m.Int64Gauge(
"system.paging.utilization",
opt...,
)
if err != nil {
return PagingUtilization{noop.Int64Gauge{}}, err
}
return PagingUtilization{i}, nil
}
// Inst returns the underlying metric instrument.
func (m PagingUtilization) Inst() metric.Int64Gauge {
return m.Int64Gauge
}
// Name returns the semantic convention name of the instrument.
func (PagingUtilization) Name() string {
return "system.paging.utilization"
}
// Unit returns the semantic convention unit of the instrument
func (PagingUtilization) Unit() string {
return "1"
}
// Description returns the semantic convention description of the instrument
func (PagingUtilization) Description() string {
return "Swap (unix) or pagefile (windows) utilization."
}
// Record records val to the current distribution for attrs.
//
// All additional attrs passed are included in the recorded value.
func (m PagingUtilization) Record(
ctx context.Context,
val int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64Gauge.Record(ctx, val)
return
}
o := recOptPool.Get().(*[]metric.RecordOption)
defer func() {
*o = (*o)[:0]
recOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64Gauge.Record(ctx, val, *o...)
}
// RecordSet records val to the current distribution for set.
func (m PagingUtilization) RecordSet(ctx context.Context, val int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64Gauge.Record(ctx, val)
return
}
o := recOptPool.Get().(*[]metric.RecordOption)
defer func() {
*o = (*o)[:0]
recOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64Gauge.Record(ctx, val, *o...)
}
// AttrDevice returns an optional attribute for the "system.device" semantic
// convention. It represents the unique identifier for the device responsible for
// managing paging operations.
func (PagingUtilization) AttrDevice(val string) attribute.KeyValue {
return attribute.String("system.device", val)
}
// AttrPagingState returns an optional attribute for the "system.paging.state"
// semantic convention. It represents the memory paging state.
func (PagingUtilization) AttrPagingState(val PagingStateAttr) attribute.KeyValue {
return attribute.String("system.paging.state", string(val))
}
// ProcessCount is an instrument used to record metric values conforming to the
// "system.process.count" semantic conventions. It represents the total number of
// processes in each state.
type ProcessCount struct {
metric.Int64UpDownCounter
}
var newProcessCountOpts = []metric.Int64UpDownCounterOption{
metric.WithDescription("Total number of processes in each state."),
metric.WithUnit("{process}"),
}
// NewProcessCount returns a new ProcessCount instrument.
func NewProcessCount(
m metric.Meter,
opt ...metric.Int64UpDownCounterOption,
) (ProcessCount, error) {
// Check if the meter is nil.
if m == nil {
return ProcessCount{noop.Int64UpDownCounter{}}, nil
}
if len(opt) == 0 {
opt = newProcessCountOpts
} else {
opt = append(opt, newProcessCountOpts...)
}
i, err := m.Int64UpDownCounter(
"system.process.count",
opt...,
)
if err != nil {
return ProcessCount{noop.Int64UpDownCounter{}}, err
}
return ProcessCount{i}, nil
}
// Inst returns the underlying metric instrument.
func (m ProcessCount) Inst() metric.Int64UpDownCounter {
return m.Int64UpDownCounter
}
// Name returns the semantic convention name of the instrument.
func (ProcessCount) Name() string {
return "system.process.count"
}
// Unit returns the semantic convention unit of the instrument
func (ProcessCount) Unit() string {
return "{process}"
}
// Description returns the semantic convention description of the instrument
func (ProcessCount) Description() string {
return "Total number of processes in each state."
}
// Add adds incr to the existing count for attrs.
//
// All additional attrs passed are included in the recorded value.
func (m ProcessCount) Add(
ctx context.Context,
incr int64,
attrs ...attribute.KeyValue,
) {
if len(attrs) == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(
*o,
metric.WithAttributes(
attrs...,
),
)
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
func (m ProcessCount) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64UpDownCounter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64UpDownCounter.Add(ctx, incr, *o...)
}
// AttrProcessState returns an optional attribute for the "process.state"
// semantic convention. It represents the process state, e.g.,
// [Linux Process State Codes].
//
// [Linux Process State Codes]: https://man7.org/linux/man-pages/man1/ps.1.html#PROCESS_STATE_CODES
func (ProcessCount) AttrProcessState(val ProcessStateAttr) attribute.KeyValue {
return attribute.String("process.state", string(val))
}
// ProcessCreated is an instrument used to record metric values conforming to the
// "system.process.created" semantic conventions. It represents the total number
// of processes created over uptime of the host.
type ProcessCreated struct {
metric.Int64Counter
}
var newProcessCreatedOpts = []metric.Int64CounterOption{
metric.WithDescription("Total number of processes created over uptime of the host."),
metric.WithUnit("{process}"),
}
// NewProcessCreated returns a new ProcessCreated instrument.
func NewProcessCreated(
m metric.Meter,
opt ...metric.Int64CounterOption,
) (ProcessCreated, error) {
// Check if the meter is nil.
if m == nil {
return ProcessCreated{noop.Int64Counter{}}, nil
}
if len(opt) == 0 {
opt = newProcessCreatedOpts
} else {
opt = append(opt, newProcessCreatedOpts...)
}
i, err := m.Int64Counter(
"system.process.created",
opt...,
)
if err != nil {
return ProcessCreated{noop.Int64Counter{}}, err
}
return ProcessCreated{i}, nil
}
// Inst returns the underlying metric instrument.
func (m ProcessCreated) Inst() metric.Int64Counter {
return m.Int64Counter
}
// Name returns the semantic convention name of the instrument.
func (ProcessCreated) Name() string {
return "system.process.created"
}
// Unit returns the semantic convention unit of the instrument
func (ProcessCreated) Unit() string {
return "{process}"
}
// Description returns the semantic convention description of the instrument
func (ProcessCreated) Description() string {
return "Total number of processes created over uptime of the host."
}
// Add adds incr to the existing count for attrs.
func (m ProcessCreated) Add(ctx context.Context, incr int64, attrs ...attribute.KeyValue) {
if len(attrs) == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributes(attrs...))
m.Int64Counter.Add(ctx, incr, *o...)
}
// AddSet adds incr to the existing count for set.
func (m ProcessCreated) AddSet(ctx context.Context, incr int64, set attribute.Set) {
if set.Len() == 0 {
m.Int64Counter.Add(ctx, incr)
return
}
o := addOptPool.Get().(*[]metric.AddOption)
defer func() {
*o = (*o)[:0]
addOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Int64Counter.Add(ctx, incr, *o...)
}
// Uptime is an instrument used to record metric values conforming to the
// "system.uptime" semantic conventions. It represents the time the system has
// been running.
type Uptime struct {
metric.Float64Gauge
}
var newUptimeOpts = []metric.Float64GaugeOption{
metric.WithDescription("The time the system has been running."),
metric.WithUnit("s"),
}
// NewUptime returns a new Uptime instrument.
func NewUptime(
m metric.Meter,
opt ...metric.Float64GaugeOption,
) (Uptime, error) {
// Check if the meter is nil.
if m == nil {
return Uptime{noop.Float64Gauge{}}, nil
}
if len(opt) == 0 {
opt = newUptimeOpts
} else {
opt = append(opt, newUptimeOpts...)
}
i, err := m.Float64Gauge(
"system.uptime",
opt...,
)
if err != nil {
return Uptime{noop.Float64Gauge{}}, err
}
return Uptime{i}, nil
}
// Inst returns the underlying metric instrument.
func (m Uptime) Inst() metric.Float64Gauge {
return m.Float64Gauge
}
// Name returns the semantic convention name of the instrument.
func (Uptime) Name() string {
return "system.uptime"
}
// Unit returns the semantic convention unit of the instrument
func (Uptime) Unit() string {
return "s"
}
// Description returns the semantic convention description of the instrument
func (Uptime) Description() string {
return "The time the system has been running."
}
// Record records val to the current distribution for attrs.
//
// Instrumentations SHOULD use a gauge with type `double` and measure uptime in
// seconds as a floating point number with the highest precision available.
// The actual accuracy would depend on the instrumentation and operating system.
func (m Uptime) Record(ctx context.Context, val float64, attrs ...attribute.KeyValue) {
if len(attrs) == 0 {
m.Float64Gauge.Record(ctx, val)
return
}
o := recOptPool.Get().(*[]metric.RecordOption)
defer func() {
*o = (*o)[:0]
recOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributes(attrs...))
m.Float64Gauge.Record(ctx, val, *o...)
}
// RecordSet records val to the current distribution for set.
//
// Instrumentations SHOULD use a gauge with type `double` and measure uptime in
// seconds as a floating point number with the highest precision available.
// The actual accuracy would depend on the instrumentation and operating system.
func (m Uptime) RecordSet(ctx context.Context, val float64, set attribute.Set) {
if set.Len() == 0 {
m.Float64Gauge.Record(ctx, val)
return
}
o := recOptPool.Get().(*[]metric.RecordOption)
defer func() {
*o = (*o)[:0]
recOptPool.Put(o)
}()
*o = append(*o, metric.WithAttributeSet(set))
m.Float64Gauge.Record(ctx, val, *o...)
}