mirror of
https://github.com/prometheus/alertmanager
synced 2025-01-27 16:43:41 +00:00
Fix potential grouping collisions, pass down group labels
This commit is contained in:
parent
a64ae57731
commit
4b49350122
3
api.go
3
api.go
@ -127,6 +127,9 @@ func (api *API) legacyAddAlerts(w http.ResponseWriter, r *http.Request) {
|
||||
Annotations: la.Payload,
|
||||
},
|
||||
}
|
||||
if a.Annotations == nil {
|
||||
a.Annotations = model.LabelSet{}
|
||||
}
|
||||
a.Annotations["summary"] = la.Summary
|
||||
a.Annotations["description"] = la.Description
|
||||
a.Annotations["runbook"] = la.Runbook
|
||||
|
26
dispatch.go
26
dispatch.go
@ -24,7 +24,7 @@ type Dispatcher struct {
|
||||
alerts provider.Alerts
|
||||
notifier notify.Notifier
|
||||
|
||||
aggrGroups map[model.Fingerprint]*aggrGroup
|
||||
aggrGroups map[*RouteOpts]map[model.Fingerprint]*aggrGroup
|
||||
|
||||
done chan struct{}
|
||||
ctx context.Context
|
||||
@ -47,7 +47,7 @@ func NewDispatcher(ap provider.Alerts, r []*config.Route, n notify.Notifier) *Di
|
||||
// Run starts dispatching alerts incoming via the updates channel.
|
||||
func (d *Dispatcher) Run() {
|
||||
d.done = make(chan struct{})
|
||||
d.aggrGroups = map[model.Fingerprint]*aggrGroup{}
|
||||
d.aggrGroups = map[*RouteOpts]map[model.Fingerprint]*aggrGroup{}
|
||||
|
||||
d.ctx, d.cancel = context.WithCancel(context.Background())
|
||||
|
||||
@ -77,10 +77,12 @@ func (d *Dispatcher) run(it provider.AlertIterator) {
|
||||
}
|
||||
|
||||
case <-cleanup.C:
|
||||
for _, ag := range d.aggrGroups {
|
||||
if ag.empty() {
|
||||
ag.stop()
|
||||
delete(d.aggrGroups, ag.fingerprint())
|
||||
for _, groups := range d.aggrGroups {
|
||||
for _, ag := range groups {
|
||||
if ag.empty() {
|
||||
ag.stop()
|
||||
delete(groups, ag.fingerprint())
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -119,11 +121,17 @@ func (d *Dispatcher) processAlert(alert *types.Alert, opts *RouteOpts) {
|
||||
|
||||
fp := group.Fingerprint()
|
||||
|
||||
groups, ok := d.aggrGroups[opts]
|
||||
if !ok {
|
||||
groups = map[model.Fingerprint]*aggrGroup{}
|
||||
d.aggrGroups[opts] = groups
|
||||
}
|
||||
|
||||
// If the group does not exist, create it.
|
||||
ag, ok := d.aggrGroups[fp]
|
||||
ag, ok := groups[fp]
|
||||
if !ok {
|
||||
ag = newAggrGroup(d.ctx, group, opts)
|
||||
d.aggrGroups[fp] = ag
|
||||
groups[fp] = ag
|
||||
|
||||
ag.log = log.With("aggrGroup", ag)
|
||||
|
||||
@ -203,8 +211,8 @@ func (ag *aggrGroup) run(nf notifyFunc) {
|
||||
ctx = notify.WithNow(ctx, now)
|
||||
|
||||
// Populate context with information needed along the pipeline.
|
||||
ctx = notify.WithGroupLabels(ctx, ag.labels)
|
||||
ctx = notify.WithDestination(ctx, ag.opts.SendTo)
|
||||
ctx = notify.WithGroup(ctx, ag.String())
|
||||
ctx = notify.WithRepeatInterval(ctx, ag.opts.RepeatInterval)
|
||||
ctx = notify.WithSendResolved(ctx, ag.opts.SendResolved)
|
||||
|
||||
|
@ -37,7 +37,7 @@ const (
|
||||
keyDestination notifyKey = iota
|
||||
keyRepeatInterval
|
||||
keySendResolved
|
||||
keyGroup
|
||||
keyGroupLabels
|
||||
keyNow
|
||||
)
|
||||
|
||||
@ -53,8 +53,8 @@ func WithSendResolved(ctx context.Context, b bool) context.Context {
|
||||
return context.WithValue(ctx, keySendResolved, b)
|
||||
}
|
||||
|
||||
func WithGroup(ctx context.Context, g string) context.Context {
|
||||
return context.WithValue(ctx, keyGroup, g)
|
||||
func WithGroupLabels(ctx context.Context, lset model.LabelSet) context.Context {
|
||||
return context.WithValue(ctx, keyGroupLabels, lset)
|
||||
}
|
||||
|
||||
func WithNow(ctx context.Context, t time.Time) context.Context {
|
||||
@ -76,8 +76,8 @@ func SendResolved(ctx context.Context) (bool, bool) {
|
||||
return v, ok
|
||||
}
|
||||
|
||||
func Group(ctx context.Context) (string, bool) {
|
||||
v, ok := ctx.Value(keyGroup).(string)
|
||||
func GroupLabels(ctx context.Context) (model.LabelSet, bool) {
|
||||
v, ok := ctx.Value(keyGroupLabels).(model.LabelSet)
|
||||
return v, ok
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user