Merge pull request #53 from prometheus/web-pprof

Remove memprofile file, add pprof HTTP endpoint instead.
This commit is contained in:
Julius Volz 2015-03-05 22:58:31 +01:00
commit 30cf7f8c73

View file

@ -6,9 +6,9 @@ import (
"fmt" "fmt"
"io/ioutil" "io/ioutil"
"net/http" "net/http"
_ "net/http/pprof"
"os" "os"
"os/signal" "os/signal"
"runtime/pprof"
"strings" "strings"
"sync" "sync"
"syscall" "syscall"
@ -171,7 +171,7 @@ func main() {
password: *authPass, password: *authPass,
} }
} }
go func() {
http.Handle(*metricsPath, handler) http.Handle(*metricsPath, handler)
http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) { http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
w.Write([]byte(`<html> w.Write([]byte(`<html>
@ -182,26 +182,8 @@ func main() {
</body> </body>
</html>`)) </html>`))
}) })
err := http.ListenAndServe(*listenAddress, nil) err = http.ListenAndServe(*listenAddress, nil)
if err != nil { if err != nil {
glog.Fatal(err) glog.Fatal(err)
} }
}()
for {
select {
case <-sigUsr1:
glog.Infof("got signal")
if *memProfile != "" {
glog.Infof("Writing memory profile to %s", *memProfile)
f, err := os.Create(*memProfile)
if err != nil {
glog.Fatal(err)
}
pprof.WriteHeapProfile(f)
f.Close()
}
}
}
} }