kubernetes/pkg/controller/resourceclaim/metrics/metrics.go
Patrick Ohly 0133df3929 kube-controller-manager: add ResourceClaim controller
The controller uses the exact same logic as the generic ephemeral inline volume
controller, just for inline ResourceClaimTemplate -> ResourceClaim.

In addition, it supports removal of pods from the ReservedFor field when those
pods are known to not need the claim anymore. At the moment, only this special
case is supported. Removal of arbitrary objects would imply granting full read
access to all types to determine whether a) an object is gone and b) if the
current incarnation is the one which is listed in ReservedFor. This may get
added later.
2022-11-10 20:23:50 +01:00

59 lines
1.8 KiB
Go

/*
Copyright 2021 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 (
"sync"
"k8s.io/component-base/metrics"
"k8s.io/component-base/metrics/legacyregistry"
)
// ResourceClaimSubsystem - subsystem name used for ResourceClaim creation
const ResourceClaimSubsystem = "resourceclaim_controller"
var (
// ResourceClaimCreateAttempts tracks the number of
// ResourceClaims().Create calls (both successful and unsuccessful)
ResourceClaimCreateAttempts = metrics.NewCounter(
&metrics.CounterOpts{
Subsystem: ResourceClaimSubsystem,
Name: "create_attempts_total",
Help: "Number of ResourceClaims creation requests",
StabilityLevel: metrics.ALPHA,
})
// ResourceClaimCreateFailures tracks the number of unsuccessful
// ResourceClaims().Create calls
ResourceClaimCreateFailures = metrics.NewCounter(
&metrics.CounterOpts{
Subsystem: ResourceClaimSubsystem,
Name: "create_failures_total",
Help: "Number of ResourceClaims creation request failures",
StabilityLevel: metrics.ALPHA,
})
)
var registerMetrics sync.Once
// RegisterMetrics registers ResourceClaim metrics.
func RegisterMetrics() {
registerMetrics.Do(func() {
legacyregistry.MustRegister(ResourceClaimCreateAttempts)
legacyregistry.MustRegister(ResourceClaimCreateFailures)
})
}