mirror of
https://github.com/prometheus/prometheus.git
synced 2025-07-04 03:23:25 +00:00
95 lines
3 KiB
Go
95 lines
3 KiB
Go
![]() |
// Copyright 2013 The Prometheus 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 notifier
|
||
|
|
||
|
import "github.com/prometheus/client_golang/prometheus"
|
||
|
|
||
|
type alertMetrics struct {
|
||
|
latency *prometheus.SummaryVec
|
||
|
errors *prometheus.CounterVec
|
||
|
sent *prometheus.CounterVec
|
||
|
dropped prometheus.Counter
|
||
|
queueLength prometheus.GaugeFunc
|
||
|
queueCapacity prometheus.Gauge
|
||
|
alertmanagersDiscovered prometheus.GaugeFunc
|
||
|
}
|
||
|
|
||
|
func newAlertMetrics(r prometheus.Registerer, queueCap int, queueLen, alertmanagersDiscovered func() float64) *alertMetrics {
|
||
|
m := &alertMetrics{
|
||
|
latency: prometheus.NewSummaryVec(prometheus.SummaryOpts{
|
||
|
Namespace: namespace,
|
||
|
Subsystem: subsystem,
|
||
|
Name: "latency_seconds",
|
||
|
Help: "Latency quantiles for sending alert notifications.",
|
||
|
Objectives: map[float64]float64{0.5: 0.05, 0.9: 0.01, 0.99: 0.001},
|
||
|
},
|
||
|
[]string{alertmanagerLabel},
|
||
|
),
|
||
|
errors: prometheus.NewCounterVec(prometheus.CounterOpts{
|
||
|
Namespace: namespace,
|
||
|
Subsystem: subsystem,
|
||
|
Name: "errors_total",
|
||
|
Help: "Total number of sent alerts affected by errors.",
|
||
|
},
|
||
|
[]string{alertmanagerLabel},
|
||
|
),
|
||
|
sent: prometheus.NewCounterVec(prometheus.CounterOpts{
|
||
|
Namespace: namespace,
|
||
|
Subsystem: subsystem,
|
||
|
Name: "sent_total",
|
||
|
Help: "Total number of alerts sent.",
|
||
|
},
|
||
|
[]string{alertmanagerLabel},
|
||
|
),
|
||
|
dropped: prometheus.NewCounter(prometheus.CounterOpts{
|
||
|
Namespace: namespace,
|
||
|
Subsystem: subsystem,
|
||
|
Name: "dropped_total",
|
||
|
Help: "Total number of alerts dropped due to errors when sending to Alertmanager.",
|
||
|
}),
|
||
|
queueLength: prometheus.NewGaugeFunc(prometheus.GaugeOpts{
|
||
|
Namespace: namespace,
|
||
|
Subsystem: subsystem,
|
||
|
Name: "queue_length",
|
||
|
Help: "The number of alert notifications in the queue.",
|
||
|
}, queueLen),
|
||
|
queueCapacity: prometheus.NewGauge(prometheus.GaugeOpts{
|
||
|
Namespace: namespace,
|
||
|
Subsystem: subsystem,
|
||
|
Name: "queue_capacity",
|
||
|
Help: "The capacity of the alert notifications queue.",
|
||
|
}),
|
||
|
alertmanagersDiscovered: prometheus.NewGaugeFunc(prometheus.GaugeOpts{
|
||
|
Name: "prometheus_notifications_alertmanagers_discovered",
|
||
|
Help: "The number of alertmanagers discovered and active.",
|
||
|
}, alertmanagersDiscovered),
|
||
|
}
|
||
|
|
||
|
m.queueCapacity.Set(float64(queueCap))
|
||
|
|
||
|
if r != nil {
|
||
|
r.MustRegister(
|
||
|
m.latency,
|
||
|
m.errors,
|
||
|
m.sent,
|
||
|
m.dropped,
|
||
|
m.queueLength,
|
||
|
m.queueCapacity,
|
||
|
m.alertmanagersDiscovered,
|
||
|
)
|
||
|
}
|
||
|
|
||
|
return m
|
||
|
}
|