mirror of
https://github.com/wader/fq.git
synced 2024-11-26 21:55:57 +03:00
52 lines
1.1 KiB
Go
52 lines
1.1 KiB
Go
package profile
|
|
|
|
import (
|
|
"log"
|
|
"os"
|
|
"runtime"
|
|
"runtime/pprof"
|
|
)
|
|
|
|
func Start(cpuProfilePath string, memProfilePath string) func() {
|
|
var deferFns []func()
|
|
|
|
if cpuProfilePath != "" {
|
|
f, err := os.Create(cpuProfilePath)
|
|
if err != nil {
|
|
log.Fatal("could not create CPU profile: ", err)
|
|
}
|
|
if err := pprof.StartCPUProfile(f); err != nil {
|
|
log.Fatal("could not start CPU profile: ", err)
|
|
} else {
|
|
deferFns = append(deferFns, func() {
|
|
pprof.StopCPUProfile()
|
|
if err := f.Close(); err != nil {
|
|
log.Fatal("could not close CPU profile: ", err)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
if memProfilePath != "" {
|
|
deferFns = append(deferFns, func() {
|
|
f, err := os.Create(memProfilePath)
|
|
if err != nil {
|
|
log.Fatal("could not create memory profile: ", err)
|
|
}
|
|
if err := pprof.WriteHeapProfile(f); err != nil {
|
|
log.Fatal("could not write memory profile: ", err)
|
|
} else {
|
|
runtime.GC() // get up-to-date statistics
|
|
if err := f.Close(); err != nil {
|
|
log.Fatal("could not close memory profile: ", err)
|
|
}
|
|
}
|
|
})
|
|
}
|
|
|
|
return func() {
|
|
for _, fn := range deferFns {
|
|
fn()
|
|
}
|
|
}
|
|
}
|