feat 优化网络库

This commit is contained in:
2026-01-03 13:19:43 +08:00
parent a565692217
commit 470f642515
19 changed files with 180 additions and 126 deletions

View File

@@ -20,6 +20,7 @@ type Module interface {
func (p *Program) Init(_ svc.Environment) error {
p.moduleList = append(p.moduleList, &ModuleBase{})
p.moduleList = append(p.moduleList, &ModuleWebsocket{})
p.moduleList = append(p.moduleList, &ModulePprof{})
for _, module := range p.moduleList {
if err := module.init(); err != nil {

44
Server/robot/app/pprof.go Normal file
View File

@@ -0,0 +1,44 @@
package app
import (
"common/log"
"context"
"errors"
"net/http"
_ "net/http/pprof"
"sync"
)
// ModulePprof pprof模块
type ModulePprof struct {
wg *sync.WaitGroup
server *http.Server
}
func (m *ModulePprof) init() error {
m.wg = &sync.WaitGroup{}
return nil
}
func (m *ModulePprof) start() error {
m.wg.Add(1)
go func() {
defer m.wg.Done()
m.server = &http.Server{
Addr: "localhost:6060",
}
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
}

View File

@@ -9,9 +9,9 @@ log:
maxAge: 7
client:
count: 100
count: 1100
usn: [ 1,1000000 ]
websocket:
address: "ws://47.108.184.184/ws/"
# address: "ws://127.0.0.1"
port: 0
# address: "ws://47.108.184.184/ws/"
address: "ws://127.0.0.1"
port: 8501

View File

@@ -6,6 +6,7 @@ import (
"google.golang.org/protobuf/proto"
"math"
"math/rand"
"sync"
"time"
)
@@ -49,14 +50,21 @@ func (_ *EnterInstance) Handle(data []byte, client *Client) {
}()
}
var s2cPositionPool = sync.Pool{
New: func() interface{} {
return &sc_pb.Message{}
},
}
type Position struct {
}
func (_ *Position) Handle(data []byte, client *Client) {
msg := &sc_pb.S2C_Position{}
if err := proto.Unmarshal(data, msg); err != nil {
log.Errorf("handle msg error")
client.Stop()
return
}
//msg := s2cPositionPool.Get().(*sc_pb.Message)
//if err := proto.Unmarshal(data, msg); err != nil {
// log.Errorf("handle msg error")
// client.Stop()
// return
//}
//s2cPositionPool.Put(msg)
}