Files
service-robot/app/pprof.go

48 lines
941 B
Go

package app
import (
"context"
"errors"
"git.hlsq.asia/mmorpg/service-common/log"
"git.hlsq.asia/mmorpg/service-common/module"
"net/http"
_ "net/http/pprof"
"sync"
)
// ModulePprof pprof模块
type ModulePprof struct {
module.DefaultModule
wg *sync.WaitGroup
server *http.Server
}
func (m *ModulePprof) Init() error {
m.wg = &sync.WaitGroup{}
return nil
}
func (m *ModulePprof) Start(ready *sync.WaitGroup) error {
m.wg.Add(1)
go func() {
defer m.wg.Done()
m.server = &http.Server{
Addr: "localhost:6060",
}
ready.Done()
if err := m.server.ListenAndServe(); err != nil && !errors.Is(err, http.ErrServerClosed) {
log.Errorf("pprof server failed: %v", err.Error())
}
log.Infof("pprof server stop.")
}()
return nil
}
func (m *ModulePprof) Stop() error {
if err := m.server.Shutdown(context.Background()); err != nil {
log.Errorf("stop pprof server failed: %v", err)
}
m.wg.Wait()
return nil
}