Add cpu profiling capability to base module

This commit is contained in:
Daniel
2020-06-03 23:11:50 +02:00
parent 328884c354
commit 381b94acb5
2 changed files with 54 additions and 1 deletions

43
core/base/profiling.go Normal file
View File

@@ -0,0 +1,43 @@
package base
import (
"context"
"flag"
"fmt"
"os"
"runtime/pprof"
)
var (
cpuProfile string
)
func init() {
flag.StringVar(&cpuProfile, "cpuprofile", "", "write cpu profile to `file`")
}
func startProfiling() {
if cpuProfile != "" {
module.StartWorker("cpu profiler", cpuProfiler)
}
}
func cpuProfiler(ctx context.Context) error {
f, err := os.Create(cpuProfile)
if err != nil {
return fmt.Errorf("could not create CPU profile: %s", err)
}
if err := pprof.StartCPUProfile(f); err != nil {
return fmt.Errorf("could not start CPU profile: %s", err)
}
// wait for shutdown
<-ctx.Done()
pprof.StopCPUProfile()
err = f.Close()
if err != nil {
return fmt.Errorf("failed to close CPU profile file: %s", err)
}
return nil
}