147 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			147 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Go
		
	
	
	
| /*
 | |
| Copyright 2015 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 provides abstractions for registering which metrics
 | |
| // to record.
 | |
| package metrics
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"net/url"
 | |
| 	"sync"
 | |
| 	"time"
 | |
| )
 | |
| 
 | |
| var registerMetrics sync.Once
 | |
| 
 | |
| // DurationMetric is a measurement of some amount of time.
 | |
| type DurationMetric interface {
 | |
| 	Observe(duration time.Duration)
 | |
| }
 | |
| 
 | |
| // ExpiryMetric sets some time of expiry. If nil, assume not relevant.
 | |
| type ExpiryMetric interface {
 | |
| 	Set(expiry *time.Time)
 | |
| }
 | |
| 
 | |
| // LatencyMetric observes client latency partitioned by verb and url.
 | |
| type LatencyMetric interface {
 | |
| 	Observe(ctx context.Context, verb string, u url.URL, latency time.Duration)
 | |
| }
 | |
| 
 | |
| // SizeMetric observes client response size partitioned by verb and host.
 | |
| type SizeMetric interface {
 | |
| 	Observe(ctx context.Context, verb string, host string, size float64)
 | |
| }
 | |
| 
 | |
| // ResultMetric counts response codes partitioned by method and host.
 | |
| type ResultMetric interface {
 | |
| 	Increment(ctx context.Context, code string, method string, host string)
 | |
| }
 | |
| 
 | |
| // CallsMetric counts calls that take place for a specific exec plugin.
 | |
| type CallsMetric interface {
 | |
| 	// Increment increments a counter per exitCode and callStatus.
 | |
| 	Increment(exitCode int, callStatus string)
 | |
| }
 | |
| 
 | |
| var (
 | |
| 	// ClientCertExpiry is the expiry time of a client certificate
 | |
| 	ClientCertExpiry ExpiryMetric = noopExpiry{}
 | |
| 	// ClientCertRotationAge is the age of a certificate that has just been rotated.
 | |
| 	ClientCertRotationAge DurationMetric = noopDuration{}
 | |
| 	// RequestLatency is the latency metric that rest clients will update.
 | |
| 	RequestLatency LatencyMetric = noopLatency{}
 | |
| 	// RequestSize is the request size metric that rest clients will update.
 | |
| 	RequestSize SizeMetric = noopSize{}
 | |
| 	// ResponseSize is the response size metric that rest clients will update.
 | |
| 	ResponseSize SizeMetric = noopSize{}
 | |
| 	// RateLimiterLatency is the client side rate limiter latency metric.
 | |
| 	RateLimiterLatency LatencyMetric = noopLatency{}
 | |
| 	// RequestResult is the result metric that rest clients will update.
 | |
| 	RequestResult ResultMetric = noopResult{}
 | |
| 	// ExecPluginCalls is the number of calls made to an exec plugin, partitioned by
 | |
| 	// exit code and call status.
 | |
| 	ExecPluginCalls CallsMetric = noopCalls{}
 | |
| )
 | |
| 
 | |
| // RegisterOpts contains all the metrics to register. Metrics may be nil.
 | |
| type RegisterOpts struct {
 | |
| 	ClientCertExpiry      ExpiryMetric
 | |
| 	ClientCertRotationAge DurationMetric
 | |
| 	RequestLatency        LatencyMetric
 | |
| 	RequestSize           SizeMetric
 | |
| 	ResponseSize          SizeMetric
 | |
| 	RateLimiterLatency    LatencyMetric
 | |
| 	RequestResult         ResultMetric
 | |
| 	ExecPluginCalls       CallsMetric
 | |
| }
 | |
| 
 | |
| // Register registers metrics for the rest client to use. This can
 | |
| // only be called once.
 | |
| func Register(opts RegisterOpts) {
 | |
| 	registerMetrics.Do(func() {
 | |
| 		if opts.ClientCertExpiry != nil {
 | |
| 			ClientCertExpiry = opts.ClientCertExpiry
 | |
| 		}
 | |
| 		if opts.ClientCertRotationAge != nil {
 | |
| 			ClientCertRotationAge = opts.ClientCertRotationAge
 | |
| 		}
 | |
| 		if opts.RequestLatency != nil {
 | |
| 			RequestLatency = opts.RequestLatency
 | |
| 		}
 | |
| 		if opts.RequestSize != nil {
 | |
| 			RequestSize = opts.RequestSize
 | |
| 		}
 | |
| 		if opts.ResponseSize != nil {
 | |
| 			ResponseSize = opts.ResponseSize
 | |
| 		}
 | |
| 		if opts.RateLimiterLatency != nil {
 | |
| 			RateLimiterLatency = opts.RateLimiterLatency
 | |
| 		}
 | |
| 		if opts.RequestResult != nil {
 | |
| 			RequestResult = opts.RequestResult
 | |
| 		}
 | |
| 		if opts.ExecPluginCalls != nil {
 | |
| 			ExecPluginCalls = opts.ExecPluginCalls
 | |
| 		}
 | |
| 	})
 | |
| }
 | |
| 
 | |
| type noopDuration struct{}
 | |
| 
 | |
| func (noopDuration) Observe(time.Duration) {}
 | |
| 
 | |
| type noopExpiry struct{}
 | |
| 
 | |
| func (noopExpiry) Set(*time.Time) {}
 | |
| 
 | |
| type noopLatency struct{}
 | |
| 
 | |
| func (noopLatency) Observe(context.Context, string, url.URL, time.Duration) {}
 | |
| 
 | |
| type noopSize struct{}
 | |
| 
 | |
| func (noopSize) Observe(context.Context, string, string, float64) {}
 | |
| 
 | |
| type noopResult struct{}
 | |
| 
 | |
| func (noopResult) Increment(context.Context, string, string, string) {}
 | |
| 
 | |
| type noopCalls struct{}
 | |
| 
 | |
| func (noopCalls) Increment(int, string) {}
 |