2017-09-01 16:09:11 +02:00
|
|
|
package profiling
|
|
|
|
|
|
|
|
import (
|
2024-08-23 20:30:58 +01:00
|
|
|
"errors"
|
2017-09-01 16:09:11 +02:00
|
|
|
"os"
|
|
|
|
"path/filepath"
|
|
|
|
"runtime/pprof"
|
|
|
|
)
|
|
|
|
|
2018-02-02 13:23:47 +01:00
|
|
|
// CPUFilename is a filename in which the CPU profiling is stored.
|
|
|
|
const CPUFilename = "status_cpu.prof"
|
2017-09-01 16:09:11 +02:00
|
|
|
|
2018-02-02 13:23:47 +01:00
|
|
|
var cpuFile *os.File
|
2017-09-01 16:09:11 +02: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 {
|
2024-08-23 20:30:58 +01:00
|
|
|
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 16:09:11 +02: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()
|
2024-08-23 20:30:58 +01:00
|
|
|
err := cpuFile.Close()
|
|
|
|
cpuFile = nil
|
|
|
|
return err
|
2017-09-01 16:09:11 +02:00
|
|
|
}
|