Add reload handler to web

This commit is contained in:
Jan Berktold 2015-08-11 09:08:17 +02:00
parent cdcfada2ac
commit 2bf7048dbb
2 changed files with 18 additions and 1 deletions

View file

@ -104,7 +104,11 @@ func Main() int {
signal.Notify(hup, syscall.SIGHUP) signal.Notify(hup, syscall.SIGHUP)
go func() { go func() {
<-hupReady <-hupReady
for range hup { for {
select {
case <-hup:
case <-webHandler.Reload():
}
reloadConfig(cfg.configFile, status, targetManager, ruleManager) reloadConfig(cfg.configFile, status, targetManager, ruleManager)
} }
}() }()

View file

@ -61,6 +61,7 @@ type Handler struct {
router *route.Router router *route.Router
quitCh chan struct{} quitCh chan struct{}
reloadCh chan bool // boolean saves as placeholder, actual value does not matter
options *Options options *Options
statusInfo *PrometheusStatus statusInfo *PrometheusStatus
@ -111,6 +112,7 @@ func New(st local.Storage, qe *promql.Engine, rm *rules.Manager, status *Prometh
h := &Handler{ h := &Handler{
router: router, router: router,
quitCh: make(chan struct{}), quitCh: make(chan struct{}),
reloadCh: make(chan bool),
options: o, options: o,
statusInfo: status, statusInfo: status,
@ -171,6 +173,7 @@ func New(st local.Storage, qe *promql.Engine, rm *rules.Manager, status *Prometh
router.Post("/-/quit", h.quit) router.Post("/-/quit", h.quit)
} }
router.Post("/reload", h.reload)
router.Get("/debug/*subpath", http.DefaultServeMux.ServeHTTP) router.Get("/debug/*subpath", http.DefaultServeMux.ServeHTTP)
return h return h
@ -181,6 +184,11 @@ func (h *Handler) Quit() <-chan struct{} {
return h.quitCh return h.quitCh
} }
func (h *Handler) Reload() <-chan bool {
return h.reloadCh
}
// Run serves the HTTP endpoints. // Run serves the HTTP endpoints.
func (h *Handler) Run() { func (h *Handler) Run() {
log.Infof("Listening on %s", h.options.ListenAddress) log.Infof("Listening on %s", h.options.ListenAddress)
@ -293,6 +301,11 @@ func (h *Handler) quit(w http.ResponseWriter, r *http.Request) {
close(h.quitCh) close(h.quitCh)
} }
func (h *Handler) reload(w http.ResponseWriter, r *http.Request) {
fmt.Fprintf(w, "Reloading configuration file...")
h.reloadCh <- true
}
func (h *Handler) getTemplateFile(name string) (string, error) { func (h *Handler) getTemplateFile(name string) (string, error) {
if h.options.UseLocalAssets { if h.options.UseLocalAssets {
file, err := ioutil.ReadFile(fmt.Sprintf("web/blob/templates/%s.html", name)) file, err := ioutil.ReadFile(fmt.Sprintf("web/blob/templates/%s.html", name))