provider

package
v0.8.3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 22, 2021 License: Apache-2.0 Imports: 18 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func NewPeriodicMetricLister

func NewPeriodicMetricLister(realLister MetricLister, updateInterval time.Duration) (MetricListerWithNotification, Runnable)

NewPeriodicMetricLister creates a MetricLister that periodically pulls the list of available metrics at the provided interval, but defers the actual act of retrieving the metrics to the supplied MetricLister.

Types

type ExternalSeriesRegistry

type ExternalSeriesRegistry interface {
	// ListAllMetrics lists all metrics known to this registry
	ListAllMetrics() []provider.ExternalMetricInfo
	QueryForMetric(namespace string, metricName string, metricSelector labels.Selector) (prom.Selector, bool, error)
}

ExternalSeriesRegistry acts as the top-level converter for transforming Kubernetes requests for external metrics into Prometheus queries.

func NewExternalSeriesRegistry

func NewExternalSeriesRegistry(lister MetricListerWithNotification) ExternalSeriesRegistry

NewExternalSeriesRegistry creates an ExternalSeriesRegistry driven by the data from the provided MetricLister.

type MetricConverter

type MetricConverter interface {
	Convert(info provider.ExternalMetricInfo, queryResult prom.QueryResult) (*external_metrics.ExternalMetricValueList, error)
}

MetricConverter provides a unified interface for converting the results of Prometheus queries into external metric types.

func NewMetricConverter

func NewMetricConverter() MetricConverter

NewMetricConverter creates a MetricCoverter, capable of converting any of the three metric types returned by the Prometheus client into external metrics types.

type MetricLister

type MetricLister interface {
	ListAllMetrics() (MetricUpdateResult, error)
}

A MetricLister provides a window into all of the metrics that are available within a given Prometheus instance, classified as either Custom or External metrics, but presented generically so that it can manage both types simultaneously.

func NewBasicMetricLister

func NewBasicMetricLister(promClient prom.Client, namers []naming.MetricNamer, lookback time.Duration) MetricLister

NewBasicMetricLister creates a MetricLister that is capable of interactly directly with Prometheus to list metrics.

type MetricListerWithNotification

type MetricListerWithNotification interface {
	MetricLister
	Runnable

	// AddNotificationReceiver registers a callback to be invoked when new metric data is available.
	AddNotificationReceiver(MetricUpdateCallback)
	// UpdateNow forces an immediate refresh from the source data. Primarily for test purposes.
	UpdateNow()
}

A MetricListerWithNotification is a MetricLister that has the ability to notify listeners when new metric data is available.

type MetricUpdateCallback

type MetricUpdateCallback func(MetricUpdateResult)

MetricUpdateCallback is a function signature for receiving periodic updates about available metrics.

type MetricUpdateResult

type MetricUpdateResult struct {
	// contains filtered or unexported fields
}

MetricUpdateResult represents the output of a periodic inspection of metrics found to be available in Prometheus. It includes both the series data the Prometheus exposed, as well as the configurational object that led to their discovery.

type Runnable

type Runnable interface {
	// Run runs the runnable forever.
	Run()
	// RunUntil runs the runnable until the given channel is closed.
	RunUntil(stopChan <-chan struct{})
}

Runnable represents something that can be run until told to stop.

func NewExternalPrometheusProvider

func NewExternalPrometheusProvider(promClient prom.Client, namers []naming.MetricNamer, updateInterval time.Duration) (provider.ExternalMetricsProvider, Runnable)

NewExternalPrometheusProvider creates an ExternalMetricsProvider capable of responding to Kubernetes requests for external metric data

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL