From 81c0ab69e03cccfa57b736d517f4d8884c1feeea Mon Sep 17 00:00:00 2001 From: Simon Pasquier Date: Mon, 22 Jan 2018 17:17:33 +0100 Subject: [PATCH] Don't reset FiredAt for inactive alerts Otherwise AlertManager receives resolved alerts where StartsAt is zero which fails the validation. --- cmd/prometheus/main.go | 2 +- rules/alerting.go | 1 - 2 files changed, 1 insertion(+), 2 deletions(-) diff --git a/cmd/prometheus/main.go b/cmd/prometheus/main.go index a5885e3762..fd6d620d6d 100644 --- a/cmd/prometheus/main.go +++ b/cmd/prometheus/main.go @@ -649,7 +649,7 @@ func computeExternalURL(u, listenAddr string) (*url.URL, error) { return eu, nil } -// sendAlerts implements a the rules.NotifyFunc for a Notifier. +// sendAlerts implements the rules.NotifyFunc for a Notifier. // It filters any non-firing alerts from the input. func sendAlerts(n *notifier.Notifier, externalURL string) rules.NotifyFunc { return func(ctx context.Context, expr string, alerts ...*rules.Alert) error { diff --git a/rules/alerting.go b/rules/alerting.go index 0a2fe74489..94f266dd9f 100644 --- a/rules/alerting.go +++ b/rules/alerting.go @@ -266,7 +266,6 @@ func (r *AlertingRule) Eval(ctx context.Context, ts time.Time, query QueryFunc, if a.State != StateInactive { a.State = StateInactive a.ResolvedAt = ts - a.FiredAt = time.Time{} } continue }