-
Notifications
You must be signed in to change notification settings - Fork 20
/
metrics.go
66 lines (53 loc) · 2.35 KB
/
metrics.go
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
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package api
import (
"io"
"github.com/rcrowley/go-metrics"
)
// Metrics is a wrapper interface for go-metrics
// support Counter, Gauge, Histogram, EWMA
type Metrics interface {
// Type returns metrics logical type, e.g. 'downstream'/'upstream', this is more like the Subsystem concept
Type() string
// Labels used to distinguish the metrics' owner for same metrics key set, like 'cluster: local_service'
Labels() map[string]string
// SortedLabels return keys and vals in stable order
SortedLabels() (keys, vals []string)
// Counter creates or returns a go-metrics counter by key
// if the key is registered by other interface, it will be panic
Counter(key string) metrics.Counter
// Gauge creates or returns a go-metrics gauge by key
// if the key is registered by other interface, it will be panic
Gauge(key string) metrics.Gauge
// Histogram creates or returns a go-metrics histogram by key
// if the key is registered by other interface, it will be panic
Histogram(key string) metrics.Histogram
// EWMA creates or returns a go-metrics ewma by key
// if the key is registered by other interface, it will be panic.
// See: https://en.wikipedia.org/wiki/Moving_average#Exponential_moving_average
EWMA(key string, alpha float64) metrics.EWMA
// Each call the given function for each registered metric.
Each(func(string, interface{}))
// UnregisterAll unregister all metrics. (Mostly for testing.)
UnregisterAll()
}
// MetricsSink flush metrics to backend storage
type MetricsSink interface {
// Flush flush given metrics
Flush(writer io.Writer, metrics []Metrics)
}