0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
1
2
3
4
|
package components
import (
"fmt"
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
5
|
"net"
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
6
|
"pro2d/common/logger"
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
7
8
9
|
"sync"
)
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
10
|
type ServerOption func(*Server)
|
77f5eec7
zhangqijia
plugin 插件热更 接口
|
11
|
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
12
|
func WithPlugin(iPlugin IPlugin) ServerOption {
|
77f5eec7
zhangqijia
plugin 插件热更 接口
|
13
14
15
16
17
|
return func(server *Server) {
server.plugins = iPlugin
}
}
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
18
|
func WithSplitter(splitter ISplitter) ServerOption {
|
77f5eec7
zhangqijia
plugin 插件热更 接口
|
19
20
21
22
23
|
return func(server *Server) {
server.splitter = splitter
}
}
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
24
|
func WithConnCbk(cb ConnectionCallback) ServerOption {
|
77f5eec7
zhangqijia
plugin 插件热更 接口
|
25
26
27
28
29
|
return func(server *Server) {
server.connectionCallback = cb
}
}
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
30
|
func WithMsgCbk(cb MessageCallback) ServerOption {
|
77f5eec7
zhangqijia
plugin 插件热更 接口
|
31
32
33
34
35
|
return func(server *Server) {
server.messageCallback = cb
}
}
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
36
|
func WithCloseCbk(cb CloseCallback) ServerOption {
|
77f5eec7
zhangqijia
plugin 插件热更 接口
|
37
38
39
40
41
|
return func(server *Server) {
server.closeCallback = cb
}
}
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
42
|
func WithTimerCbk(cb TimerCallback) ServerOption {
|
77f5eec7
zhangqijia
plugin 插件热更 接口
|
43
44
45
46
47
|
return func(server *Server) {
server.timerCallback = cb
}
}
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
48
49
|
type Server struct {
|
77f5eec7
zhangqijia
plugin 插件热更 接口
|
50
51
52
|
PluginPath string
plugins IPlugin
splitter ISplitter
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
53
|
|
9a9d092e
zhangqijia
每条连接增加一个定时器,每条连接增...
|
54
55
56
57
|
connectionCallback ConnectionCallback
messageCallback MessageCallback
closeCallback CloseCallback
timerCallback TimerCallback
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
58
|
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
59
|
port int
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
60
61
62
|
Clients *sync.Map
}
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
63
|
func NewServer(port int, options ...ServerOption) IServer {
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
64
|
s := &Server{
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
65
|
port: port,
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
66
67
|
Clients: new(sync.Map),
}
|
77f5eec7
zhangqijia
plugin 插件热更 接口
|
68
69
70
71
|
for _, option := range options {
option(s)
}
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
|
return s
}
func (s *Server) GetSplitter() ISplitter {
return s.splitter
}
func (s *Server) GetIConnection(id int) IConnection {
c, ok := s.Clients.Load(id)
if !ok {
return nil
}
return c.(IConnection)
}
|
77f5eec7
zhangqijia
plugin 插件热更 接口
|
87
88
89
90
|
func (s *Server) GetPlugin() IPlugin {
return s.plugins
}
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
91
92
93
94
|
func (s *Server) GetAction(cmd uint32) interface{} {
return s.plugins.GetAction(cmd)
}
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
95
96
97
98
99
100
101
102
103
104
105
106
107
|
func (s *Server) SetConnectionCallback(cb ConnectionCallback) {
s.connectionCallback = cb
}
func (s *Server) SetMessageCallback(cb MessageCallback) {
s.messageCallback = cb
}
func (s *Server) SetCloseCallback(cb CloseCallback) {
s.closeCallback = cb
}
func (s *Server) SetTimerCallback(cb TimerCallback) {
|
9a9d092e
zhangqijia
每条连接增加一个定时器,每条连接增...
|
108
|
s.timerCallback = cb
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
109
110
|
}
|
77f5eec7
zhangqijia
plugin 插件热更 接口
|
111
112
113
|
func (s *Server) Start() error {
if err := s.plugins.LoadPlugin(); err != nil {
return err
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
114
|
}
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
115
|
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
|
port := fmt.Sprintf(":%d", s.port)
l, err := net.Listen("tcp", port)
if err != nil {
return err
}
//监听端口
logger.Debug("listen on %s\n", port)
id := 0
for {
conn, err := l.Accept()
if err != nil {
return err
}
id++
client := NewConn(id, conn, s)
s.newConnection(client)
}
}
func (s *Server)Stop() {
StopTimer()
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
138
|
|
0e5d52de
zhangqijia
reactor: 重构底层框架1.0
|
139
140
141
142
143
144
|
s.Clients.Range(func(key, value interface{}) bool {
client := value.(IConnection)
client.Stop()
return true
})
}
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
|
func (s *Server) newConnection(conn IConnection) {
s.Clients.Store(conn.GetID(), conn)
conn.SetConnectionCallback(s.connectionCallback)
conn.SetCloseCallback(s.removeConnection)
conn.SetMessageCallback(s.messageCallback)
conn.SetTimerCallback(s.timerCallback)
go conn.Start()
}
func (s *Server) removeConnection(conn IConnection) {
s.closeCallback(conn)
s.Clients.Delete(conn.GetID())
}
|