-
Notifications
You must be signed in to change notification settings - Fork 174
/
metrics.go
93 lines (86 loc) · 4.01 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
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
/*
Copyright 2018 The Kubernetes Authors.
Licensed 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 metrics
import (
"github.com/prometheus/client_golang/prometheus"
)
// Metrics contains the metrics for a certain subsystem name.
type Metrics struct {
// PersistentVolumeClaimProvisionTotal is used to collect accumulated count of persistent volumes provisioned.
PersistentVolumeClaimProvisionTotal *prometheus.CounterVec
// PersistentVolumeClaimProvisionFailedTotal is used to collect accumulated count of persistent volume provision failed attempts.
PersistentVolumeClaimProvisionFailedTotal *prometheus.CounterVec
// PersistentVolumeClaimProvisionDurationSeconds is used to collect latency in seconds to provision persistent volumes.
PersistentVolumeClaimProvisionDurationSeconds *prometheus.HistogramVec
// PersistentVolumeDeleteTotal is used to collect accumulated count of persistent volumes deleted.
PersistentVolumeDeleteTotal *prometheus.CounterVec
// PersistentVolumeDeleteFailedTotal is used to collect accumulated count of persistent volume delete failed attempts.
PersistentVolumeDeleteFailedTotal *prometheus.CounterVec
// PersistentVolumeDeleteDurationSeconds is used to collect latency in seconds to delete persistent volumes.
PersistentVolumeDeleteDurationSeconds *prometheus.HistogramVec
}
// New creates a new set of metrics with the goven subsystem name.
func New(subsystem string) Metrics {
return Metrics{
PersistentVolumeClaimProvisionTotal: prometheus.NewCounterVec(
prometheus.CounterOpts{
Subsystem: subsystem,
Name: "persistentvolumeclaim_provision_total",
Help: "Total number of persistent volumes provisioned succesfully. Broken down by storage class name and source of the claim.",
},
[]string{"class", "source"},
),
PersistentVolumeClaimProvisionFailedTotal: prometheus.NewCounterVec(
prometheus.CounterOpts{
Subsystem: subsystem,
Name: "persistentvolumeclaim_provision_failed_total",
Help: "Total number of persistent volume provision failed attempts. Broken down by storage class name and source of the claim.",
},
[]string{"class", "source"},
),
PersistentVolumeClaimProvisionDurationSeconds: prometheus.NewHistogramVec(
prometheus.HistogramOpts{
Subsystem: subsystem,
Name: "persistentvolumeclaim_provision_duration_seconds",
Help: "Latency in seconds to provision persistent volumes. Failed provisioning attempts are ignored. Broken down by storage class name and source of the claim.",
Buckets: prometheus.DefBuckets,
},
[]string{"class", "source"},
),
PersistentVolumeDeleteTotal: prometheus.NewCounterVec(
prometheus.CounterOpts{
Subsystem: subsystem,
Name: "persistentvolume_delete_total",
Help: "Total number of persistent volumes deleted succesfully. Broken down by storage class name.",
},
[]string{"class"},
),
PersistentVolumeDeleteFailedTotal: prometheus.NewCounterVec(
prometheus.CounterOpts{
Subsystem: subsystem,
Name: "persistentvolume_delete_failed_total",
Help: "Total number of persistent volume delete failed attempts. Broken down by storage class name.",
},
[]string{"class"},
),
PersistentVolumeDeleteDurationSeconds: prometheus.NewHistogramVec(
prometheus.HistogramOpts{
Subsystem: subsystem,
Name: "persistentvolume_delete_duration_seconds",
Help: "Latency in seconds to delete persistent volumes. Failed deletion attempts are ignored. Broken down by storage class name.",
Buckets: prometheus.DefBuckets,
},
[]string{"class"},
),
}
}