mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-12 06:17:27 -08:00
discovery/kubernetes: fix client metrics
The Kubernetes client records workqueue duration and latency metrics as seconds so there's no need to convert the values from microseconds to seconds anymore. The cache metrics (prometheus_sd_kubernetes_cache_*) are removed because they aren't used anymore by the client though still exposed by its API. Signed-off-by: Simon Pasquier <spasquie@redhat.com>
This commit is contained in:
parent
eba5e02718
commit
75470f86b4
|
@ -19,15 +19,11 @@ import (
|
||||||
|
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
|
|
||||||
"k8s.io/client-go/tools/cache"
|
|
||||||
"k8s.io/client-go/tools/metrics"
|
"k8s.io/client-go/tools/metrics"
|
||||||
"k8s.io/client-go/util/workqueue"
|
"k8s.io/client-go/util/workqueue"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const workqueueMetricsNamespace = metricsNamespace + "_workqueue"
|
||||||
cacheMetricsNamespace = metricsNamespace + "_cache"
|
|
||||||
workqueueMetricsNamespace = metricsNamespace + "_workqueue"
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
var (
|
||||||
// Metrics for client-go's HTTP requests.
|
// Metrics for client-go's HTTP requests.
|
||||||
|
@ -49,68 +45,6 @@ var (
|
||||||
[]string{"endpoint"},
|
[]string{"endpoint"},
|
||||||
)
|
)
|
||||||
|
|
||||||
// Definition of metrics for client-go cache metrics provider.
|
|
||||||
clientGoCacheListTotalMetric = prometheus.NewCounter(
|
|
||||||
prometheus.CounterOpts{
|
|
||||||
Namespace: cacheMetricsNamespace,
|
|
||||||
Name: "list_total",
|
|
||||||
Help: "Total number of list operations.",
|
|
||||||
},
|
|
||||||
)
|
|
||||||
clientGoCacheListDurationMetric = prometheus.NewSummary(
|
|
||||||
prometheus.SummaryOpts{
|
|
||||||
Namespace: cacheMetricsNamespace,
|
|
||||||
Name: "list_duration_seconds",
|
|
||||||
Help: "Duration of a Kubernetes API call in seconds.",
|
|
||||||
Objectives: map[float64]float64{},
|
|
||||||
},
|
|
||||||
)
|
|
||||||
clientGoCacheItemsInListCountMetric = prometheus.NewSummary(
|
|
||||||
prometheus.SummaryOpts{
|
|
||||||
Namespace: cacheMetricsNamespace,
|
|
||||||
Name: "list_items",
|
|
||||||
Help: "Count of items in a list from the Kubernetes API.",
|
|
||||||
Objectives: map[float64]float64{},
|
|
||||||
},
|
|
||||||
)
|
|
||||||
clientGoCacheWatchesCountMetric = prometheus.NewCounter(
|
|
||||||
prometheus.CounterOpts{
|
|
||||||
Namespace: cacheMetricsNamespace,
|
|
||||||
Name: "watches_total",
|
|
||||||
Help: "Total number of watch operations.",
|
|
||||||
},
|
|
||||||
)
|
|
||||||
clientGoCacheShortWatchesCountMetric = prometheus.NewCounter(
|
|
||||||
prometheus.CounterOpts{
|
|
||||||
Namespace: cacheMetricsNamespace,
|
|
||||||
Name: "short_watches_total",
|
|
||||||
Help: "Total number of short watch operations.",
|
|
||||||
},
|
|
||||||
)
|
|
||||||
clientGoCacheWatchesDurationMetric = prometheus.NewSummary(
|
|
||||||
prometheus.SummaryOpts{
|
|
||||||
Namespace: cacheMetricsNamespace,
|
|
||||||
Name: "watch_duration_seconds",
|
|
||||||
Help: "Duration of watches on the Kubernetes API.",
|
|
||||||
Objectives: map[float64]float64{},
|
|
||||||
},
|
|
||||||
)
|
|
||||||
clientGoCacheItemsInWatchesCountMetric = prometheus.NewSummary(
|
|
||||||
prometheus.SummaryOpts{
|
|
||||||
Namespace: cacheMetricsNamespace,
|
|
||||||
Name: "watch_events",
|
|
||||||
Help: "Number of items in watches on the Kubernetes API.",
|
|
||||||
Objectives: map[float64]float64{},
|
|
||||||
},
|
|
||||||
)
|
|
||||||
clientGoCacheLastResourceVersionMetric = prometheus.NewGauge(
|
|
||||||
prometheus.GaugeOpts{
|
|
||||||
Namespace: cacheMetricsNamespace,
|
|
||||||
Name: "last_resource_version",
|
|
||||||
Help: "Last resource version from the Kubernetes API.",
|
|
||||||
},
|
|
||||||
)
|
|
||||||
|
|
||||||
// Definition of metrics for client-go workflow metrics provider
|
// Definition of metrics for client-go workflow metrics provider
|
||||||
clientGoWorkqueueDepthMetricVec = prometheus.NewGaugeVec(
|
clientGoWorkqueueDepthMetricVec = prometheus.NewGaugeVec(
|
||||||
prometheus.GaugeOpts{
|
prometheus.GaugeOpts{
|
||||||
|
@ -189,47 +123,6 @@ func (clientGoRequestMetricAdapter) Observe(verb string, u url.URL, latency time
|
||||||
clientGoRequestLatencyMetricVec.WithLabelValues(u.EscapedPath()).Observe(latency.Seconds())
|
clientGoRequestLatencyMetricVec.WithLabelValues(u.EscapedPath()).Observe(latency.Seconds())
|
||||||
}
|
}
|
||||||
|
|
||||||
// Definition of client-go cache metrics provider definition
|
|
||||||
type clientGoCacheMetricsProvider struct{}
|
|
||||||
|
|
||||||
func (f *clientGoCacheMetricsProvider) Register(registerer prometheus.Registerer) {
|
|
||||||
cache.SetReflectorMetricsProvider(f)
|
|
||||||
registerer.MustRegister(
|
|
||||||
clientGoCacheWatchesDurationMetric,
|
|
||||||
clientGoCacheWatchesCountMetric,
|
|
||||||
clientGoCacheListDurationMetric,
|
|
||||||
clientGoCacheListTotalMetric,
|
|
||||||
clientGoCacheLastResourceVersionMetric,
|
|
||||||
clientGoCacheShortWatchesCountMetric,
|
|
||||||
clientGoCacheItemsInWatchesCountMetric,
|
|
||||||
clientGoCacheItemsInListCountMetric,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
func (clientGoCacheMetricsProvider) NewListsMetric(name string) cache.CounterMetric {
|
|
||||||
return clientGoCacheListTotalMetric
|
|
||||||
}
|
|
||||||
func (clientGoCacheMetricsProvider) NewListDurationMetric(name string) cache.SummaryMetric {
|
|
||||||
return clientGoCacheListDurationMetric
|
|
||||||
}
|
|
||||||
func (clientGoCacheMetricsProvider) NewItemsInListMetric(name string) cache.SummaryMetric {
|
|
||||||
return clientGoCacheItemsInListCountMetric
|
|
||||||
}
|
|
||||||
func (clientGoCacheMetricsProvider) NewWatchesMetric(name string) cache.CounterMetric {
|
|
||||||
return clientGoCacheWatchesCountMetric
|
|
||||||
}
|
|
||||||
func (clientGoCacheMetricsProvider) NewShortWatchesMetric(name string) cache.CounterMetric {
|
|
||||||
return clientGoCacheShortWatchesCountMetric
|
|
||||||
}
|
|
||||||
func (clientGoCacheMetricsProvider) NewWatchDurationMetric(name string) cache.SummaryMetric {
|
|
||||||
return clientGoCacheWatchesDurationMetric
|
|
||||||
}
|
|
||||||
func (clientGoCacheMetricsProvider) NewItemsInWatchMetric(name string) cache.SummaryMetric {
|
|
||||||
return clientGoCacheItemsInWatchesCountMetric
|
|
||||||
}
|
|
||||||
func (clientGoCacheMetricsProvider) NewLastResourceVersionMetric(name string) cache.GaugeMetric {
|
|
||||||
return clientGoCacheLastResourceVersionMetric
|
|
||||||
}
|
|
||||||
|
|
||||||
// Definition of client-go workqueue metrics provider definition
|
// Definition of client-go workqueue metrics provider definition
|
||||||
type clientGoWorkqueueMetricsProvider struct{}
|
type clientGoWorkqueueMetricsProvider struct{}
|
||||||
|
|
||||||
|
@ -252,18 +145,10 @@ func (f *clientGoWorkqueueMetricsProvider) NewAddsMetric(name string) workqueue.
|
||||||
return clientGoWorkqueueAddsMetricVec.WithLabelValues(name)
|
return clientGoWorkqueueAddsMetricVec.WithLabelValues(name)
|
||||||
}
|
}
|
||||||
func (f *clientGoWorkqueueMetricsProvider) NewLatencyMetric(name string) workqueue.HistogramMetric {
|
func (f *clientGoWorkqueueMetricsProvider) NewLatencyMetric(name string) workqueue.HistogramMetric {
|
||||||
metric := clientGoWorkqueueLatencyMetricVec.WithLabelValues(name)
|
return clientGoWorkqueueLatencyMetricVec.WithLabelValues(name)
|
||||||
// Convert microseconds to seconds for consistency across metrics.
|
|
||||||
return prometheus.ObserverFunc(func(v float64) {
|
|
||||||
metric.Observe(v / 1e6)
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
func (f *clientGoWorkqueueMetricsProvider) NewWorkDurationMetric(name string) workqueue.HistogramMetric {
|
func (f *clientGoWorkqueueMetricsProvider) NewWorkDurationMetric(name string) workqueue.HistogramMetric {
|
||||||
metric := clientGoWorkqueueWorkDurationMetricVec.WithLabelValues(name)
|
return clientGoWorkqueueWorkDurationMetricVec.WithLabelValues(name)
|
||||||
// Convert microseconds to seconds for consistency across metrics.
|
|
||||||
return prometheus.ObserverFunc(func(v float64) {
|
|
||||||
metric.Observe(v / 1e6)
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
func (f *clientGoWorkqueueMetricsProvider) NewUnfinishedWorkSecondsMetric(name string) workqueue.SettableGaugeMetric {
|
func (f *clientGoWorkqueueMetricsProvider) NewUnfinishedWorkSecondsMetric(name string) workqueue.SettableGaugeMetric {
|
||||||
return clientGoWorkqueueUnfinishedWorkSecondsMetricVec.WithLabelValues(name)
|
return clientGoWorkqueueUnfinishedWorkSecondsMetricVec.WithLabelValues(name)
|
||||||
|
|
|
@ -139,12 +139,10 @@ func init() {
|
||||||
|
|
||||||
var (
|
var (
|
||||||
clientGoRequestMetricAdapterInstance = clientGoRequestMetricAdapter{}
|
clientGoRequestMetricAdapterInstance = clientGoRequestMetricAdapter{}
|
||||||
clientGoCacheMetricsProviderInstance = clientGoCacheMetricsProvider{}
|
|
||||||
clientGoWorkqueueMetricsProviderInstance = clientGoWorkqueueMetricsProvider{}
|
clientGoWorkqueueMetricsProviderInstance = clientGoWorkqueueMetricsProvider{}
|
||||||
)
|
)
|
||||||
|
|
||||||
clientGoRequestMetricAdapterInstance.Register(prometheus.DefaultRegisterer)
|
clientGoRequestMetricAdapterInstance.Register(prometheus.DefaultRegisterer)
|
||||||
clientGoCacheMetricsProviderInstance.Register(prometheus.DefaultRegisterer)
|
|
||||||
clientGoWorkqueueMetricsProviderInstance.Register(prometheus.DefaultRegisterer)
|
clientGoWorkqueueMetricsProviderInstance.Register(prometheus.DefaultRegisterer)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue