Blame view

common/components/server.go 2.86 KB
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())
  }