|
|
|
package prof
|
|
|
|
|
|
|
|
import "github.com/tal-tech/go-zero/core/utils"
|
|
|
|
|
|
|
|
type (
|
|
|
|
// A ProfilePoint is a profile time point.
|
|
|
|
ProfilePoint struct {
|
|
|
|
*utils.ElapsedTimer
|
|
|
|
}
|
|
|
|
|
|
|
|
// A Profiler interface represents a profiler that used to report profile points.
|
|
|
|
Profiler interface {
|
|
|
|
Start() ProfilePoint
|
|
|
|
Report(name string, point ProfilePoint)
|
|
|
|
}
|
|
|
|
|
|
|
|
realProfiler struct{}
|
|
|
|
|
|
|
|
nullProfiler struct{}
|
|
|
|
)
|
|
|
|
|
|
|
|
var profiler = newNullProfiler()
|
|
|
|
|
|
|
|
// EnableProfiling enables profiling.
|
|
|
|
func EnableProfiling() {
|
|
|
|
profiler = newRealProfiler()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Start starts a Profiler, and returns a start profiling point.
|
|
|
|
func Start() ProfilePoint {
|
|
|
|
return profiler.Start()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Report reports a ProfilePoint with given name.
|
|
|
|
func Report(name string, point ProfilePoint) {
|
|
|
|
profiler.Report(name, point)
|
|
|
|
}
|
|
|
|
|
|
|
|
func newRealProfiler() Profiler {
|
|
|
|
return &realProfiler{}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (rp *realProfiler) Start() ProfilePoint {
|
|
|
|
return ProfilePoint{
|
|
|
|
ElapsedTimer: utils.NewElapsedTimer(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (rp *realProfiler) Report(name string, point ProfilePoint) {
|
|
|
|
duration := point.Duration()
|
|
|
|
report(name, duration)
|
|
|
|
}
|
|
|
|
|
|
|
|
func newNullProfiler() Profiler {
|
|
|
|
return &nullProfiler{}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (np *nullProfiler) Start() ProfilePoint {
|
|
|
|
return ProfilePoint{}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (np *nullProfiler) Report(string, ProfilePoint) {
|
|
|
|
}
|