diff --git a/main.go b/main.go index 27a529c..633fad9 100644 --- a/main.go +++ b/main.go @@ -15,6 +15,7 @@ package main import ( "bufio" + "fmt" "net" "net/http" _ "net/http/pprof" @@ -250,6 +251,7 @@ func main() { var ( listenAddress = kingpin.Flag("web.listen-address", "The address on which to expose the web interface and generated Prometheus metrics.").Default(":9102").String() enableLifecycle = kingpin.Flag("web.enable-lifecycle", "Enable shutdown and reload via HTTP request.").Default("false").Bool() + enableHealthEndpoint = kingpin.Flag("web.enable-health-path", "Enable health check via HTTP request.").Default("true").Bool() metricsEndpoint = kingpin.Flag("web.telemetry-path", "Path under which to expose metrics.").Default("/metrics").String() statsdListenUDP = kingpin.Flag("statsd.listen-udp", "The UDP address on which to receive statsd metric lines. \"\" disables it.").Default(":9125").String() statsdListenTCP = kingpin.Flag("statsd.listen-tcp", "The TCP address on which to receive statsd metric lines. \"\" disables it.").Default(":9125").String() @@ -494,6 +496,16 @@ func main() { }) } + if *enableHealthEndpoint { + mux.HandleFunc("/-/healthy", func(w http.ResponseWriter, r *http.Request) { + if r.Method == http.MethodGet { + level.Debug(logger).Log("msg", "Received health check") + w.WriteHeader(http.StatusOK) + fmt.Fprintf(w, "Statsd Exporter is Healthy.\n") + } + }) + } + go serveHTTP(mux, *listenAddress, logger) signals := make(chan os.Signal, 1)