Skip to content

Commit

Permalink
pkg/debugutil: add 'mutex' profiler (Go 1.8+)
Browse files Browse the repository at this point in the history
Signed-off-by: Gyu-Ho Lee <gyuhox@gmail.com>
  • Loading branch information
gyuho committed Apr 18, 2017
1 parent dd0d590 commit 5161b74
Showing 1 changed file with 8 additions and 0 deletions.
8 changes: 8 additions & 0 deletions pkg/debugutil/pprof.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,12 +17,19 @@ package debugutil
import (
"net/http"
"net/http/pprof"
"runtime"
)

const HTTPPrefixPProf = "/debug/pprof"

// PProfHandlers returns a map of pprof handlers keyed by the HTTP path.
func PProfHandlers() map[string]http.Handler {
// set only when there's no existing setting
if runtime.SetMutexProfileFraction(-1) == 0 {
// 1 out of 5 mutex events are reported, on average
runtime.SetMutexProfileFraction(5)
}

m := make(map[string]http.Handler)

m[HTTPPrefixPProf+"/"] = http.HandlerFunc(pprof.Index)
Expand All @@ -34,6 +41,7 @@ func PProfHandlers() map[string]http.Handler {
m[HTTPPrefixPProf+"/goroutine"] = pprof.Handler("goroutine")
m[HTTPPrefixPProf+"/threadcreate"] = pprof.Handler("threadcreate")
m[HTTPPrefixPProf+"/block"] = pprof.Handler("block")
m[HTTPPrefixPProf+"/mutex"] = pprof.Handler("mutex")

return m
}

0 comments on commit 5161b74

Please sign in to comment.