status-go/profiling/cpu.go

41 lines
869 B
Go
Raw Permalink Normal View History

2017-09-01 14:09:11 +00:00
package profiling
import (
"errors"
2017-09-01 14:09:11 +00:00
"os"
"path/filepath"
"runtime/pprof"
)
// CPUFilename is a filename in which the CPU profiling is stored.
const CPUFilename = "status_cpu.prof"
2017-09-01 14:09:11 +00:00
var cpuFile *os.File
2017-09-01 14:09:11 +00:00
// StartCPUProfile enables CPU profiling for the current process. While profiling,
// the profile will be buffered and written to the file in folder dataDir.
func StartCPUProfile(dataDir string) error {
if cpuFile != nil {
return errors.New("cpu profiling is already started")
}
var err error
cpuFile, err = os.Create(filepath.Join(dataDir, CPUFilename))
if err != nil {
return err
2017-09-01 14:09:11 +00:00
}
return pprof.StartCPUProfile(cpuFile)
}
// StopCPUProfile stops the current CPU profile, if any, and closes the file.
func StopCPUProfile() error {
if cpuFile == nil {
return nil
}
pprof.StopCPUProfile()
err := cpuFile.Close()
cpuFile = nil
return err
2017-09-01 14:09:11 +00:00
}