coredns/middleware/pprof/pprof.go
Miek Gieben 5301c5af5f Run golint and go vet (#276)
Cleanup the errors and removed deadcode along the way. The leaves
some error laying around, mostly about commenting exported identifier.
We should look hard if those really are needed.
2016-09-21 17:01:19 +01:00

47 lines
779 B
Go

package pprof
import (
"log"
"net"
"net/http"
pp "net/http/pprof"
)
type Handler struct {
ln net.Listener
mux *http.ServeMux
}
func (h *Handler) Startup() error {
ln, err := net.Listen("tcp", addr)
if err != nil {
log.Printf("[ERROR] Failed to start pprof handler: %s", err)
return err
}
h.ln = ln
h.mux = http.NewServeMux()
h.mux.HandleFunc(path+"/", pp.Index)
h.mux.HandleFunc(path+"/cmdline", pp.Cmdline)
h.mux.HandleFunc(path+"/profile", pp.Profile)
h.mux.HandleFunc(path+"/symbol", pp.Symbol)
h.mux.HandleFunc(path+"/trace", pp.Trace)
go func() {
http.Serve(h.ln, h.mux)
}()
return nil
}
func (h *Handler) Shutdown() error {
if h.ln != nil {
return h.ln.Close()
}
return nil
}
const (
addr = "localhost:6053"
path = "/debug/pprof"
)