fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
1
2
3
4
5
|
package net
import (
"bufio"
"fmt"
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
6
|
"math"
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
7
|
"net"
|
cad2b7f3
zhangqijia
reactor: 重构目录, 重构...
|
8
9
|
"pro2d/src/common"
"pro2d/src/components/logger"
|
38dd96b4
zhangqijia
定时器+网络数据 peer 在一条...
|
10
|
"pro2d/src/models"
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
11
12
|
"pro2d/src/utils"
"sync/atomic"
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
13
14
15
16
17
18
19
20
21
22
23
24
|
)
type Head struct {
Length int32
Cmd int32
ErrCode int32
PreField int32
}
type Connection struct {
net.Conn
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
25
26
|
Id int
Server *Server
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
27
|
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
28
29
|
scanner *bufio.Scanner
writer *bufio.Writer
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
30
|
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
31
|
WBuffer chan []byte
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
32
|
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
33
34
|
Quit chan *Connection
|
38dd96b4
zhangqijia
定时器+网络数据 peer 在一条...
|
35
36
|
Role *models.RoleModel
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
37
38
39
|
nextCheckTime int64 //下一次检查的时间
lastHeartCheckTime int64 //最后收消息时间
heartTimeoutCount int //超时次数
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
40
41
42
|
}
type MsgPkg struct {
|
9644352a
zhangqijia
登录服改为http,游戏服改为长连...
|
43
|
Head *Head
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
44
45
46
47
48
49
50
51
52
53
|
Body []byte
Conn *Connection
}
func NewConn(id int, conn net.Conn, s *Server) *Connection {
return &Connection{
Id: id,
Conn: conn,
Server: s,
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
54
55
56
|
scanner: bufio.NewScanner(conn),
writer: bufio.NewWriter(conn),
WBuffer: make(chan []byte),
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
57
58
59
|
Quit: make(chan *Connection),
lastHeartCheckTime: utils.Timex(),
heartTimeoutCount: 0,
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
60
61
62
63
64
65
66
|
}
}
func (c *Connection) write() {
defer c.Quiting()
for msg := range c.WBuffer {
|
98b0736d
zhangqijia
添加定时器, 检查心跳
|
67
68
69
|
n, err := c.writer.Write(msg)
if err != nil{
logger.Error("write fail err: " + err.Error(), "n: ", n)
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
70
71
72
|
return
}
if err := c.writer.Flush(); err != nil {
|
98b0736d
zhangqijia
添加定时器, 检查心跳
|
73
|
logger.Error("write Flush fail err: " + err.Error())
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
74
75
|
return
}
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
76
77
78
79
80
|
}
}
func (c *Connection) read() {
defer c.Quiting()
|
5d9cf01c
zhangqijia
plugin 热更
|
81
|
c.scanner.Split(ParseMsg)
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
82
|
|
5d9cf01c
zhangqijia
plugin 热更
|
83
84
85
|
for c.scanner.Scan() {
req, err := DecodeMsg(c.scanner.Bytes())
if err != nil {
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
86
87
|
return
}
|
5d9cf01c
zhangqijia
plugin 热更
|
88
89
90
91
92
|
req.Conn = c
//得到需要处理此条连接的workerID
workerID := c.Id % c.Server.SConf.WorkerPoolSize
//将请求消息发送给任务队列
|
38dd96b4
zhangqijia
定时器+网络数据 peer 在一条...
|
93
94
95
|
c.Server.TaskQueue[workerID] <- func() {
c.Server.DoMsgHandler(req)
}
|
5d9cf01c
zhangqijia
plugin 热更
|
96
|
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
97
98
|
atomic.StoreInt64(&c.lastHeartCheckTime, utils.Timex())
|
5d9cf01c
zhangqijia
plugin 热更
|
99
100
101
102
103
104
|
//备注,可以在当前协程处理当条请求(如下, 实现很简单,已经删除),也可以丢到协程池里处理任务(如上),还未对比效果。
//c.Server.OnRecv(req)
}
if err := c.scanner.Err(); err != nil {
fmt.Printf("scanner.err: %s\n", err.Error())
|
5d9cf01c
zhangqijia
plugin 热更
|
105
|
return
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
106
107
108
|
}
}
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
109
110
111
|
func (c *Connection) checkHeartBeat(now int64) {
lastHeartCheckTime := atomic.LoadInt64(&c.lastHeartCheckTime)
logger.Debug("checkHeartBeat ID: %d, last: %d, now: %d", c.Id, lastHeartCheckTime, now)
|
33ea26ab
zhangqijia
使用schema封装mongo
|
112
|
if math.Abs(float64(lastHeartCheckTime - now)) > common.HeartTimerInterval {
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
113
|
c.heartTimeoutCount++
|
33ea26ab
zhangqijia
使用schema封装mongo
|
114
|
if c.heartTimeoutCount >= common.HeartTimeoutCountMax {
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
115
116
117
118
119
120
121
122
123
124
125
126
127
|
c.Quiting()
return
}
logger.Debug("timeout count: %d", c.heartTimeoutCount)
}else {
c.heartTimeoutCount = 0
}
}
func (c *Connection) update() {
nextCheckTime := atomic.LoadInt64(&c.nextCheckTime)
now := utils.Timex()
if now >= nextCheckTime {
|
38dd96b4
zhangqijia
定时器+网络数据 peer 在一条...
|
128
|
//检查心跳
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
129
|
c.checkHeartBeat(now)
|
33ea26ab
zhangqijia
使用schema封装mongo
|
130
|
nextCheckTime = now + common.HeartTimerInterval
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
131
132
|
atomic.StoreInt64(&c.nextCheckTime, nextCheckTime)
}
|
38dd96b4
zhangqijia
定时器+网络数据 peer 在一条...
|
133
134
135
136
137
138
139
|
if c.Role != nil {
c.Server.TaskQueue[c.Id % c.Server.SConf.WorkerPoolSize] <- func() {
//role 获取Recover
c.Role.OnRecoverTimer(now)
}
}
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
140
|
}
|
33ea26ab
zhangqijia
使用schema封装mongo
|
141
|
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
142
|
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
143
144
145
|
func (c *Connection) Start() {
go c.write()
go c.read()
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
146
147
148
|
}
func (c *Connection) Stop() {
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
149
150
151
152
|
c.Conn.Close()
}
func (c *Connection) Quiting() {
|
0cc58315
zhangqijia
添加定时器, 检查心跳
|
153
|
logger.Debug("ID: %d close", c.Id)
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
154
155
156
|
c.Server.OnClose(c)
}
|
9644352a
zhangqijia
登录服改为http,游戏服改为长连...
|
157
158
159
160
161
162
163
164
165
166
167
168
169
|
func (c *Connection) SendMsgByCode(errCode int32, cmd int32, data []byte){
h := &Head{
Length: int32(common.HEADLEN + len(data)),
Cmd: cmd,
ErrCode: errCode,
PreField: 0,
}
pkg := &MsgPkg{
Head: h,
Body: data,
}
buf, err := EncodeMsg(pkg)
if err != nil {
|
cad2b7f3
zhangqijia
reactor: 重构目录, 重构...
|
170
|
logger.Error("SendMsg error: %v", err)
|
9644352a
zhangqijia
登录服改为http,游戏服改为长连...
|
171
172
173
|
return
}
c.WBuffer <- buf
|
fee11bff
zhangqijia
客户端无法使用grpc热更,不用g...
|
174
|
}
|