alertmanager/main.go

106 lines
2.8 KiB
Go
Raw Normal View History

// 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 (
2013-07-22 09:05:49 +00:00
"flag"
"log"
"os"
"time"
2013-08-05 09:49:56 +00:00
"github.com/prometheus/alertmanager/config"
"github.com/prometheus/alertmanager/manager"
"github.com/prometheus/alertmanager/web"
"github.com/prometheus/alertmanager/web/api"
)
2013-07-26 01:04:53 +00:00
var (
configFile = flag.String("configFile", "alertmanager.conf", "Alert Manager configuration file name.")
silencesFile = flag.String("silencesFile", "silences.json", "Silence storage file name.")
2013-07-26 01:04:53 +00:00
)
func main() {
2013-07-22 09:05:49 +00:00
flag.Parse()
versionInfoTmpl.Execute(os.Stdout, BuildInfo)
2013-08-02 15:22:26 +00:00
conf := config.MustLoadFromFile(*configFile)
2013-07-26 01:04:53 +00:00
silencer := manager.NewSilencer()
defer silencer.Close()
2013-08-02 15:22:26 +00:00
err := silencer.LoadFromFile(*silencesFile)
if err != nil {
log.Println("Couldn't load silences, starting up with empty silence list:", err)
}
saveSilencesTicker := time.NewTicker(10 * time.Second)
go func() {
for _ = range saveSilencesTicker.C {
if err := silencer.SaveToFile(*silencesFile); err != nil {
log.Println("Error saving silences to file:", err)
}
}
}()
defer saveSilencesTicker.Stop()
2013-07-30 11:19:18 +00:00
notifier := manager.NewNotifier(conf.NotificationConfig)
defer notifier.Close()
2013-07-30 11:19:18 +00:00
aggregator := manager.NewAggregator(notifier)
defer aggregator.Close()
flags := map[string]string{}
flag.VisitAll(func(f *flag.Flag) {
flags[f.Name] = f.Value.String()
})
statusHandler := &web.StatusHandler{
Config: conf.String(),
Flags: flags,
BuildInfo: BuildInfo,
Birth: time.Now(),
}
webService := &web.WebService{
// REST API Service.
AlertManagerService: &api.AlertManagerService{
Aggregator: aggregator,
Silencer: silencer,
},
// Template-based page handlers.
AlertsHandler: &web.AlertsHandler{
Aggregator: aggregator,
IsInhibitedInterrogator: silencer,
},
SilencesHandler: &web.SilencesHandler{
Silencer: silencer,
},
StatusHandler: statusHandler,
}
go webService.ServeForever()
2013-07-30 11:19:18 +00:00
aggregator.SetRules(conf.AggregationRules())
2013-08-02 15:22:26 +00:00
watcher := config.NewFileWatcher(*configFile)
go watcher.Watch(func(conf *config.Config) {
notifier.SetNotificationConfigs(conf.NotificationConfig)
aggregator.SetRules(conf.AggregationRules())
statusHandler.UpdateConfig(conf.String())
2013-08-02 15:22:26 +00:00
})
log.Println("Running summary dispatcher...")
notifier.Dispatch(silencer)
}