Merge pull request #478 from kunalkushwaha/profiler
Exposing pprof and expvars interfaces on default containerd socket
This commit is contained in:
commit
e1eeb40d1d
1 changed files with 28 additions and 0 deletions
|
@ -1,9 +1,11 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
_ "expvar"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net"
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
_ "net/http/pprof"
|
||||||
"net/url"
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
"os/signal"
|
"os/signal"
|
||||||
|
@ -66,6 +68,11 @@ func main() {
|
||||||
Usage: "socket path for containerd's GRPC server",
|
Usage: "socket path for containerd's GRPC server",
|
||||||
Value: "/run/containerd/containerd.sock",
|
Value: "/run/containerd/containerd.sock",
|
||||||
},
|
},
|
||||||
|
cli.StringFlag{
|
||||||
|
Name: "debug-socket, d",
|
||||||
|
Usage: "socket path for containerd's debug server",
|
||||||
|
Value: "/run/containerd/containerd-debug.sock",
|
||||||
|
},
|
||||||
cli.StringFlag{
|
cli.StringFlag{
|
||||||
Name: "metrics-address, m",
|
Name: "metrics-address, m",
|
||||||
Usage: "tcp address to serve metrics on",
|
Usage: "tcp address to serve metrics on",
|
||||||
|
@ -101,6 +108,21 @@ func main() {
|
||||||
}
|
}
|
||||||
defer s.Shutdown()
|
defer s.Shutdown()
|
||||||
|
|
||||||
|
debugPath := context.GlobalString("debug-socket")
|
||||||
|
if debugPath == "" {
|
||||||
|
return fmt.Errorf("--debug-socket path cannot be empty")
|
||||||
|
}
|
||||||
|
d, err := utils.CreateUnixSocket(debugPath)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
//publish profiling and debug socket.
|
||||||
|
log.G(ctx).WithField("socket", debugPath).Info("starting profiler handlers")
|
||||||
|
log.G(ctx).WithFields(logrus.Fields{"expvars": "/debug/vars", "socket": debugPath}).Debug("serving expvars requests")
|
||||||
|
log.G(ctx).WithFields(logrus.Fields{"pprof": "/debug/pprof", "socket": debugPath}).Debug("serving pprof requests")
|
||||||
|
go serveProfiler(ctx, d)
|
||||||
|
|
||||||
path := context.GlobalString("socket")
|
path := context.GlobalString("socket")
|
||||||
if path == "" {
|
if path == "" {
|
||||||
return fmt.Errorf("--socket path cannot be empty")
|
return fmt.Errorf("--socket path cannot be empty")
|
||||||
|
@ -194,6 +216,12 @@ func serveGRPC(ctx gocontext.Context, server *grpc.Server, l net.Listener) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func serveProfiler(ctx gocontext.Context, l net.Listener) {
|
||||||
|
if err := http.Serve(l, nil); err != nil {
|
||||||
|
log.G(ctx).WithError(err).Fatal("profiler server failure")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// DumpStacks dumps the runtime stack.
|
// DumpStacks dumps the runtime stack.
|
||||||
func dumpStacks(ctx gocontext.Context) {
|
func dumpStacks(ctx gocontext.Context) {
|
||||||
var (
|
var (
|
||||||
|
|
Loading…
Reference in a new issue