istio

Форк
0
109 строк · 2.6 Кб
1
/*
2
Copyright 2018 The Kubernetes Authors.
3

4
Licensed under the Apache License, Version 2.0 (the "License");
5
you may not use this file except in compliance with the License.
6
You may obtain a copy of the License at
7

8
    http://www.apache.org/licenses/LICENSE-2.0
9

10
Unless required by applicable law or agreed to in writing, software
11
distributed under the License is distributed on an "AS IS" BASIS,
12
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
See the License for the specific language governing permissions and
14
limitations under the License.
15
*/
16

17
package k8sleaderelection
18

19
import (
20
	"sync"
21
)
22

23
// This file provides abstractions for setting the provider (e.g., prometheus)
24
// of metrics.
25

26
type leaderMetricsAdapter interface {
27
	leaderOn(name string)
28
	leaderOff(name string)
29
}
30

31
// GaugeMetric represents a single numerical value that can arbitrarily go up
32
// and down.
33
type SwitchMetric interface {
34
	On(name string)
35
	Off(name string)
36
}
37

38
type noopMetric struct{}
39

40
func (noopMetric) On(name string)  {}
41
func (noopMetric) Off(name string) {}
42

43
// defaultLeaderMetrics expects the caller to lock before setting any metrics.
44
type defaultLeaderMetrics struct {
45
	// leader's value indicates if the current process is the owner of name lease
46
	leader SwitchMetric
47
}
48

49
func (m *defaultLeaderMetrics) leaderOn(name string) {
50
	if m == nil {
51
		return
52
	}
53
	m.leader.On(name)
54
}
55

56
func (m *defaultLeaderMetrics) leaderOff(name string) {
57
	if m == nil {
58
		return
59
	}
60
	m.leader.Off(name)
61
}
62

63
type noMetrics struct{}
64

65
func (noMetrics) leaderOn(name string)  {}
66
func (noMetrics) leaderOff(name string) {}
67

68
// MetricsProvider generates various metrics used by the leader election.
69
type MetricsProvider interface {
70
	NewLeaderMetric() SwitchMetric
71
}
72

73
type noopMetricsProvider struct{}
74

75
func (noopMetricsProvider) NewLeaderMetric() SwitchMetric {
76
	return noopMetric{}
77
}
78

79
var globalMetricsFactory = leaderMetricsFactory{
80
	metricsProvider: noopMetricsProvider{},
81
}
82

83
type leaderMetricsFactory struct {
84
	metricsProvider MetricsProvider
85

86
	onlyOnce sync.Once
87
}
88

89
func (f *leaderMetricsFactory) setProvider(mp MetricsProvider) {
90
	f.onlyOnce.Do(func() {
91
		f.metricsProvider = mp
92
	})
93
}
94

95
func (f *leaderMetricsFactory) newLeaderMetrics() leaderMetricsAdapter {
96
	mp := f.metricsProvider
97
	if mp == (noopMetricsProvider{}) {
98
		return noMetrics{}
99
	}
100
	return &defaultLeaderMetrics{
101
		leader: mp.NewLeaderMetric(),
102
	}
103
}
104

105
// SetProvider sets the metrics provider for all subsequently created work
106
// queues. Only the first call has an effect.
107
func SetProvider(metricsProvider MetricsProvider) {
108
	globalMetricsFactory.setProvider(metricsProvider)
109
}
110

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.