alertmanager/main.go

71 lines
1.8 KiB
Go

// Copyright 2013 Prometheus Team
// 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 main
import (
"flag"
"log"
"github.com/prometheus/alert_manager/manager"
"github.com/prometheus/alert_manager/web"
"github.com/prometheus/alert_manager/web/api"
)
func main() {
flag.Parse()
log.Print("Starting event suppressor...")
suppressor := manager.NewSuppressor()
defer suppressor.Close()
go suppressor.Dispatch()
log.Println("Done.")
log.Println("Starting event aggregator...")
aggregator := manager.NewAggregator()
defer aggregator.Close()
summarizer := manager.NewSummaryDispatcher()
go aggregator.Dispatch(summarizer)
log.Println("Done.")
webService := &web.WebService{
AlertManagerService: &api.AlertManagerService{
Aggregator: aggregator,
},
AlertsHandler: &web.AlertsHandler{
Aggregator: aggregator,
},
}
go webService.ServeForever()
// BEGIN EXAMPLE CODE - replace with config loading later.
done := make(chan bool)
go func() {
rules := manager.AggregationRules{
&manager.AggregationRule{
Filters: manager.Filters{manager.NewFilter("service", "discovery")},
},
}
aggregator.SetRules(rules)
done <- true
}()
<-done
// END EXAMPLE CODE
log.Println("Running summary dispatcher...")
summarizer.Dispatch(suppressor)
}