|
|
|
@ -81,6 +81,18 @@ var (
|
|
|
|
|
Name: "rule_group_iterations_total",
|
|
|
|
|
Help: "The total number of scheduled rule group evaluations, whether executed or missed.",
|
|
|
|
|
})
|
|
|
|
|
lastDuration = prometheus.NewDesc(
|
|
|
|
|
prometheus.BuildFQName(namespace, "", "rule_group_last_duration_seconds"),
|
|
|
|
|
"The duration of the last rule group evaulation.",
|
|
|
|
|
[]string{"rule_group"},
|
|
|
|
|
nil,
|
|
|
|
|
)
|
|
|
|
|
groupInterval = prometheus.NewDesc(
|
|
|
|
|
prometheus.BuildFQName(namespace, "", "rule_group_interval_seconds"),
|
|
|
|
|
"The interval of a rule group.",
|
|
|
|
|
[]string{"rule_group"},
|
|
|
|
|
nil,
|
|
|
|
|
)
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
@ -444,17 +456,22 @@ type ManagerOptions struct {
|
|
|
|
|
Context context.Context
|
|
|
|
|
Appendable Appendable
|
|
|
|
|
Logger log.Logger
|
|
|
|
|
Registerer prometheus.Registerer
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// NewManager returns an implementation of Manager, ready to be started
|
|
|
|
|
// by calling the Run method.
|
|
|
|
|
func NewManager(o *ManagerOptions) *Manager {
|
|
|
|
|
return &Manager{
|
|
|
|
|
m := &Manager{
|
|
|
|
|
groups: map[string]*Group{},
|
|
|
|
|
opts: o,
|
|
|
|
|
block: make(chan struct{}),
|
|
|
|
|
logger: o.Logger,
|
|
|
|
|
}
|
|
|
|
|
if o.Registerer != nil {
|
|
|
|
|
o.Registerer.MustRegister(m)
|
|
|
|
|
}
|
|
|
|
|
return m
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Run starts processing of the rule manager.
|
|
|
|
@ -627,3 +644,25 @@ func (m *Manager) AlertingRules() []*AlertingRule {
|
|
|
|
|
}
|
|
|
|
|
return alerts
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Implements prometheus.Collector.
|
|
|
|
|
func (m *Manager) Describe(ch chan<- *prometheus.Desc) {
|
|
|
|
|
ch <- lastDuration
|
|
|
|
|
ch <- groupInterval
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Implements prometheus.Collector.
|
|
|
|
|
func (m *Manager) Collect(ch chan<- prometheus.Metric) {
|
|
|
|
|
for _, g := range m.RuleGroups() {
|
|
|
|
|
ch <- prometheus.MustNewConstMetric(lastDuration,
|
|
|
|
|
prometheus.GaugeValue,
|
|
|
|
|
g.GetEvaluationTime().Seconds(),
|
|
|
|
|
groupKey(g.file, g.name))
|
|
|
|
|
}
|
|
|
|
|
for _, g := range m.RuleGroups() {
|
|
|
|
|
ch <- prometheus.MustNewConstMetric(groupInterval,
|
|
|
|
|
prometheus.GaugeValue,
|
|
|
|
|
g.interval.Seconds(),
|
|
|
|
|
groupKey(g.file, g.name))
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|