cubefs

Форк
0
/
alarm.go 
56 строк · 1.2 Кб
1
// Copyright 2018 The CubeFS Authors.
2
//
3
// Licensed under the Apache License, Version 2.0 (the "License");
4
// you may not use this file except in compliance with the License.
5
// You may obtain a copy of the License at
6
//
7
//     http://www.apache.org/licenses/LICENSE-2.0
8
//
9
// Unless required by applicable law or agreed to in writing, software
10
// distributed under the License is distributed on an "AS IS" BASIS,
11
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
12
// implied. See the License for the specific language governing
13
// permissions and limitations under the License.
14

15
package exporter
16

17
import (
18
	"fmt"
19
	"sync"
20

21
	"github.com/cubefs/cubefs/util/log"
22
	"github.com/cubefs/cubefs/util/ump"
23
)
24

25
var (
26
	AlarmPool = &sync.Pool{New: func() interface{} {
27
		return new(Alarm)
28
	}}
29
	// AlarmGroup  sync.Map
30
	AlarmCh chan *Alarm
31
)
32

33
func collectAlarm() {
34
	AlarmCh = make(chan *Alarm, ChSize)
35
	for {
36
		m := <-AlarmCh
37
		AlarmPool.Put(m)
38
	}
39
}
40

41
type Alarm struct {
42
	Counter
43
}
44

45
func Warning(detail string) (a *Alarm) {
46
	key := fmt.Sprintf("%v_%v_warning", clustername, modulename)
47
	ump.Alarm(key, detail)
48
	log.LogCritical(key, detail)
49
	if !enabledPrometheus {
50
		return
51
	}
52
	a = AlarmPool.Get().(*Alarm)
53
	a.name = metricsName(key)
54
	a.Add(1)
55
	return
56
}
57

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

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

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

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