1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
|
// Package metrics provides interface collecting performance metrics.
package metrics
import (
"context"
"time"
)
// Gauge tracks single float64 value.
type Gauge interface {
Set(value float64)
Add(value float64)
}
// FuncGauge is Gauge with value provided by callback function.
type FuncGauge interface {
Function() func() float64
}
// Counter tracks monotonically increasing value.
type Counter interface {
// Inc increments counter by 1.
Inc()
// Add adds delta to the counter. Delta must be >=0.
Add(delta int64)
}
// FuncCounter is Counter with value provided by callback function.
type FuncCounter interface {
Function() func() int64
}
// Histogram tracks distribution of value.
type Histogram interface {
RecordValue(value float64)
}
// Timer measures durations.
type Timer interface {
RecordDuration(value time.Duration)
}
// DurationBuckets defines buckets of the duration histogram.
type DurationBuckets interface {
// Size returns number of buckets.
Size() int
// MapDuration returns index of the bucket.
//
// index is integer in range [0, Size()).
MapDuration(d time.Duration) int
// UpperBound of the last bucket is always +Inf.
//
// bucketIndex is integer in range [0, Size()-1).
UpperBound(bucketIndex int) time.Duration
}
// Buckets defines intervals of the regular histogram.
type Buckets interface {
// Size returns number of buckets.
Size() int
// MapValue returns index of the bucket.
//
// Index is integer in range [0, Size()).
MapValue(v float64) int
// UpperBound of the last bucket is always +Inf.
//
// bucketIndex is integer in range [0, Size()-1).
UpperBound(bucketIndex int) float64
}
// GaugeVec stores multiple dynamically created gauges.
type GaugeVec interface {
With(map[string]string) Gauge
// Reset deletes all metrics in vector.
Reset()
}
// CounterVec stores multiple dynamically created counters.
type CounterVec interface {
With(map[string]string) Counter
// Reset deletes all metrics in vector.
Reset()
}
// TimerVec stores multiple dynamically created timers.
type TimerVec interface {
With(map[string]string) Timer
// Reset deletes all metrics in vector.
Reset()
}
// HistogramVec stores multiple dynamically created histograms.
type HistogramVec interface {
With(map[string]string) Histogram
// Reset deletes all metrics in vector.
Reset()
}
// Registry creates profiling metrics.
type Registry interface {
// WithTags creates new sub-scope, where each metric has tags attached to it.
WithTags(tags map[string]string) Registry
// WithPrefix creates new sub-scope, where each metric has prefix added to it name.
WithPrefix(prefix string) Registry
ComposeName(parts ...string) string
Counter(name string) Counter
CounterVec(name string, labels []string) CounterVec
FuncCounter(name string, function func() int64) FuncCounter
Gauge(name string) Gauge
GaugeVec(name string, labels []string) GaugeVec
FuncGauge(name string, function func() float64) FuncGauge
Timer(name string) Timer
TimerVec(name string, labels []string) TimerVec
Histogram(name string, buckets Buckets) Histogram
HistogramVec(name string, buckets Buckets, labels []string) HistogramVec
DurationHistogram(name string, buckets DurationBuckets) Timer
DurationHistogramVec(name string, buckets DurationBuckets, labels []string) TimerVec
}
// CollectPolicy defines how registered gauge metrics are updated via collect func.
type CollectPolicy interface {
RegisteredCounter(counterFunc func() int64) func() int64
RegisteredGauge(gaugeFunc func() float64) func() float64
AddCollect(collect func(ctx context.Context))
}
|