Documentation ¶
Index ¶
- Constants
- Variables
- func ActivePods() metrics.GaugeMetric
- func BackoffPods() metrics.GaugeMetric
- func GatedPods() metrics.GaugeMetric
- func GetGather() metrics.Gatherer
- func InitMetrics()
- func PodScheduleError(profile string, duration float64)
- func PodScheduled(profile string, duration float64)
- func PodUnschedulable(profile string, duration float64)
- func Register()
- func RegisterMetrics(extraMetrics ...metrics.Registerable)
- func SinceInSeconds(start time.Time) float64
- func UnschedulablePods() metrics.GaugeMetric
- func UnschedulableReason(plugin string, profile string) metrics.GaugeMetric
- type MetricAsyncRecorder
- func (r *MetricAsyncRecorder) FlushMetrics()
- func (r *MetricAsyncRecorder) ObserveInFlightEventsAsync(eventLabel string, valueToAdd float64, forceFlush bool)
- func (r *MetricAsyncRecorder) ObservePluginDurationAsync(extensionPoint, pluginName, status string, value float64)
- func (r *MetricAsyncRecorder) ObserveQueueingHintDurationAsync(pluginName, event, hint string, value float64)
- type MetricRecorder
- type PendingPodsRecorder
Constants ¶
const ( // PrioritizingExtender - prioritizing extender work/operation label value. PrioritizingExtender = "prioritizing_extender" // Binding - binding work/operation label value. Binding = "binding" )
Below are possible values for the work and operation label.
const ( GoroutineResultSuccess = "success" GoroutineResultError = "error" )
const ( PreFilter = "PreFilter" Filter = "Filter" PreFilterExtensionAddPod = "PreFilterExtensionAddPod" PreFilterExtensionRemovePod = "PreFilterExtensionRemovePod" PostFilter = "PostFilter" PreScore = "PreScore" Score = "Score" ScoreExtensionNormalize = "ScoreExtensionNormalize" PreBind = "PreBind" Bind = "Bind" PostBind = "PostBind" Reserve = "Reserve" Unreserve = "Unreserve" Permit = "Permit" )
const ( QueueingHintResultQueue = "Queue" QueueingHintResultQueueSkip = "QueueSkip" QueueingHintResultError = "Error" )
const (
PodPoppedInFlightEvent = "PodPopped"
)
const (
// SchedulerSubsystem - subsystem name used by scheduler.
SchedulerSubsystem = "scheduler"
)
Variables ¶
var ( EventHandlingLatency *metrics.HistogramVec SchedulingAlgorithmLatency *metrics.Histogram PreemptionVictims *metrics.Histogram PreemptionAttempts *metrics.Counter InFlightEvents *metrics.GaugeVec Goroutines *metrics.GaugeVec // PodSchedulingDuration is deprecated as of Kubernetes v1.28, and will be removed // in v1.31. Please use PodSchedulingSLIDuration instead. PodSchedulingDuration *metrics.HistogramVec PodSchedulingSLIDuration *metrics.HistogramVec PodSchedulingAttempts *metrics.Histogram FrameworkExtensionPointDuration *metrics.HistogramVec PluginExecutionDuration *metrics.HistogramVec PermitWaitDuration *metrics.HistogramVec CacheSize *metrics.GaugeVec PluginEvaluationTotal *metrics.CounterVec SchedulerQueueIncomingPods *metrics.CounterVec // The below two are only available when the async-preemption feature gate is enabled. PreemptionGoroutinesDuration *metrics.HistogramVec PreemptionGoroutinesExecutionTotal *metrics.CounterVec )
All the histogram based metrics have 1ms as size for the smallest bucket.
var ( ScheduledResult = "scheduled" UnschedulableResult = "unschedulable" ErrorResult = "error" )
var ExtentionPoints = []string{ PreFilter, Filter, PreFilterExtensionAddPod, PreFilterExtensionRemovePod, PostFilter, PreScore, Score, ScoreExtensionNormalize, PreBind, Bind, PostBind, Reserve, Unreserve, Permit, }
ExtentionPoints is a list of possible values for the extension_point label.
Functions ¶
func ActivePods ¶ added in v1.15.0
func ActivePods() metrics.GaugeMetric
ActivePods returns the pending pods metrics with the label active
func BackoffPods ¶ added in v1.15.0
func BackoffPods() metrics.GaugeMetric
BackoffPods returns the pending pods metrics with the label backoff
func GatedPods ¶ added in v1.26.0
func GatedPods() metrics.GaugeMetric
GatedPods returns the pending pods metrics with the label gated
func GetGather ¶ added in v1.17.0
GetGather returns the gatherer. It used by test case outside current package.
func InitMetrics ¶ added in v1.32.0
func InitMetrics()
func PodScheduleError ¶ added in v1.19.0
PodScheduleError can records a scheduling attempt that had an error and the duration since `start`.
func PodScheduled ¶ added in v1.19.0
PodScheduled can records a successful scheduling attempt and the duration since `start`.
func PodUnschedulable ¶ added in v1.19.0
PodUnschedulable can records a scheduling attempt for an unschedulable pod and the duration since `start`.
func RegisterMetrics ¶ added in v1.19.0
func RegisterMetrics(extraMetrics ...metrics.Registerable)
RegisterMetrics registers a list of metrics. This function is exported because it is intended to be used by out-of-tree plugins to register their custom metrics.
func SinceInSeconds ¶ added in v1.11.0
SinceInSeconds gets the time since the specified start in seconds.
func UnschedulablePods ¶ added in v1.15.0
func UnschedulablePods() metrics.GaugeMetric
UnschedulablePods returns the pending pods metrics with the label unschedulable
func UnschedulableReason ¶ added in v1.24.0
func UnschedulableReason(plugin string, profile string) metrics.GaugeMetric
Types ¶
type MetricAsyncRecorder ¶ added in v1.27.0
type MetricAsyncRecorder struct { // IsStoppedCh indicates whether the goroutine is stopped. It's used in tests only to make sure // the metric flushing goroutine is stopped so that tests can collect metrics for verification. IsStoppedCh chan struct{} // contains filtered or unexported fields }
MetricAsyncRecorder records metric in a separate goroutine to avoid overhead in the critical path.
func NewMetricsAsyncRecorder ¶ added in v1.27.0
func NewMetricsAsyncRecorder(bufferSize int, interval time.Duration, stopCh <-chan struct{}) *MetricAsyncRecorder
func (*MetricAsyncRecorder) FlushMetrics ¶ added in v1.27.0
func (r *MetricAsyncRecorder) FlushMetrics()
FlushMetrics tries to clean up the bufferCh by reading at most bufferSize metrics.
func (*MetricAsyncRecorder) ObserveInFlightEventsAsync ¶ added in v1.32.0
func (r *MetricAsyncRecorder) ObserveInFlightEventsAsync(eventLabel string, valueToAdd float64, forceFlush bool)
ObserveInFlightEventsAsync observes the in_flight_events metric.
Note that this function is not goroutine-safe; we don't lock the map deliberately for the performance reason and we assume the queue (i.e., the caller) takes lock before updating the in-flight events.
func (*MetricAsyncRecorder) ObservePluginDurationAsync ¶ added in v1.27.0
func (r *MetricAsyncRecorder) ObservePluginDurationAsync(extensionPoint, pluginName, status string, value float64)
ObservePluginDurationAsync observes the plugin_execution_duration_seconds metric. The metric will be flushed to Prometheus asynchronously.
func (*MetricAsyncRecorder) ObserveQueueingHintDurationAsync ¶ added in v1.31.0
func (r *MetricAsyncRecorder) ObserveQueueingHintDurationAsync(pluginName, event, hint string, value float64)
ObserveQueueingHintDurationAsync observes the queueing_hint_execution_duration_seconds metric. The metric will be flushed to Prometheus asynchronously.
type MetricRecorder ¶ added in v1.15.0
type MetricRecorder interface { Inc() Dec() Clear() }
MetricRecorder represents a metric recorder which takes action when the metric Inc(), Dec() and Clear()
type PendingPodsRecorder ¶ added in v1.15.0
type PendingPodsRecorder struct {
// contains filtered or unexported fields
}
PendingPodsRecorder is an implementation of MetricRecorder
func NewActivePodsRecorder ¶ added in v1.15.0
func NewActivePodsRecorder() *PendingPodsRecorder
NewActivePodsRecorder returns ActivePods in a Prometheus metric fashion
func NewBackoffPodsRecorder ¶ added in v1.15.0
func NewBackoffPodsRecorder() *PendingPodsRecorder
NewBackoffPodsRecorder returns BackoffPods in a Prometheus metric fashion
func NewGatedPodsRecorder ¶ added in v1.26.0
func NewGatedPodsRecorder() *PendingPodsRecorder
NewGatedPodsRecorder returns GatedPods in a Prometheus metric fashion
func NewUnschedulablePodsRecorder ¶ added in v1.15.0
func NewUnschedulablePodsRecorder() *PendingPodsRecorder
NewUnschedulablePodsRecorder returns UnschedulablePods in a Prometheus metric fashion
func (*PendingPodsRecorder) Clear ¶ added in v1.15.0
func (r *PendingPodsRecorder) Clear()
Clear set a metric counter to 0, in an atomic way
func (*PendingPodsRecorder) Dec ¶ added in v1.15.0
func (r *PendingPodsRecorder) Dec()
Dec decreases a metric counter by 1, in an atomic way
func (*PendingPodsRecorder) Inc ¶ added in v1.15.0
func (r *PendingPodsRecorder) Inc()
Inc increases a metric counter by 1, in an atomic way
Directories ¶
Path | Synopsis |
---|---|
Package resources provides a metrics collector that reports the resource consumption (requests and limits) of the pods in the cluster as the scheduler and kubelet would interpret it.
|
Package resources provides a metrics collector that reports the resource consumption (requests and limits) of the pods in the cluster as the scheduler and kubelet would interpret it. |