Blame view

src/components/net/conn.go 3.51 KB
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
  }