ee23102d
zhangqijia
支持mongo, grpc接服务器
|
1
2
3
4
5
6
7
|
package actions
import (
"context"
"google.golang.org/grpc"
"google.golang.org/grpc/reflection"
"pro2d/conf"
|
3592dfd3
zhangqijia
重构models, 索引唯一索引
|
8
|
"pro2d/models"
|
ee23102d
zhangqijia
支持mongo, grpc接服务器
|
9
10
11
12
13
14
15
16
17
18
19
|
"pro2d/protos/pb"
"pro2d/utils"
)
type AccountServer struct{
pb.UnimplementedAccountServer
*BasicServer
}
func NewAccountServer() *AccountServer {
return &AccountServer{
|
286f6dbe
zhangqijia
etcd 保存服务信息
|
20
|
BasicServer: NewServer(),
|
ee23102d
zhangqijia
支持mongo, grpc接服务器
|
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
}
}
//拦截器
func AccountServerInterceptor(ctx context.Context, req interface{}, info *grpc.UnaryServerInfo,
handler grpc.UnaryHandler) (interface{}, error) {
utils.Sugar.Debugf("gRPC method: %s, %v", info.FullMethod, req)
resp, err := handler(ctx, req)
return resp, err
}
func (s *AccountServer)Start() error {
lis, err := s.BasicServer.Start(conf.GlobalConf.AccountConf)
if err != nil {
return err
}
|
3592dfd3
zhangqijia
重构models, 索引唯一索引
|
39
40
|
models.InitAccountServerModels()
|
ee23102d
zhangqijia
支持mongo, grpc接服务器
|
41
|
//new一个grpc
|
f7f4beb5
zhangqijia
新增grpc平滑关闭,修复crea...
|
42
|
s.GrpcServer = grpc.NewServer(grpc.UnaryInterceptor(AccountServerInterceptor))
|
ee23102d
zhangqijia
支持mongo, grpc接服务器
|
43
|
|
f7f4beb5
zhangqijia
新增grpc平滑关闭,修复crea...
|
44
45
|
pb.RegisterAccountServer(s.GrpcServer, s)
reflection.Register(s.GrpcServer) //在给定的gRPC服务器上注册服务器反射服务
|
ee23102d
zhangqijia
支持mongo, grpc接服务器
|
46
47
48
49
50
|
// Serve方法在lis上接受传入连接,为每个连接创建一个ServerTransport和server的goroutine。
// 该goroutine读取gRPC请求,然后调用已注册的处理程序来响应它们。
utils.Sugar.Debugf("Start AccountServer listening on %d", conf.GlobalConf.AccountConf.Port)
|
f7f4beb5
zhangqijia
新增grpc平滑关闭,修复crea...
|
51
|
return s.GrpcServer.Serve(lis)
|
ee23102d
zhangqijia
支持mongo, grpc接服务器
|
52
53
54
|
}
func (s *AccountServer)Stop() {
|
f7f4beb5
zhangqijia
新增grpc平滑关闭,修复crea...
|
55
|
s.BasicServer.Stop()
|
ee23102d
zhangqijia
支持mongo, grpc接服务器
|
56
57
|
}
|
ee23102d
zhangqijia
支持mongo, grpc接服务器
|
58
59
60
61
62
63
64
|
type GameServer struct{
pb.UnimplementedGameServer
*BasicServer
}
func NewGameServer() *GameServer {
return &GameServer{
|
286f6dbe
zhangqijia
etcd 保存服务信息
|
65
|
BasicServer: NewServer(),
|
ee23102d
zhangqijia
支持mongo, grpc接服务器
|
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
|
}
}
//拦截器
func GameServerInterceptor(ctx context.Context, req interface{}, info *grpc.UnaryServerInfo,
handler grpc.UnaryHandler) (interface{}, error) {
utils.Sugar.Debugf("gRPC method: %s, %v", info.FullMethod, req)
resp, err := handler(ctx, req)
return resp, err
}
func (s *GameServer)Start() error {
lis, err := s.BasicServer.Start(conf.GlobalConf.GameConf)
if err != nil {
return err
}
|
3592dfd3
zhangqijia
重构models, 索引唯一索引
|
83
84
|
models.InitGameServerModels()
|
ee23102d
zhangqijia
支持mongo, grpc接服务器
|
85
|
//new一个grpc
|
f7f4beb5
zhangqijia
新增grpc平滑关闭,修复crea...
|
86
|
s.GrpcServer = grpc.NewServer(grpc.UnaryInterceptor(GameServerInterceptor))
|
ee23102d
zhangqijia
支持mongo, grpc接服务器
|
87
|
|
f7f4beb5
zhangqijia
新增grpc平滑关闭,修复crea...
|
88
89
|
pb.RegisterGameServer(s.GrpcServer, s)
reflection.Register(s.GrpcServer) //在给定的gRPC服务器上注册服务器反射服务
|
ee23102d
zhangqijia
支持mongo, grpc接服务器
|
90
91
92
93
|
// Serve方法在lis上接受传入连接,为每个连接创建一个ServerTransport和server的goroutine。
// 该goroutine读取gRPC请求,然后调用已注册的处理程序来响应它们。
utils.Sugar.Debugf("Start GameServer listening on %d", conf.GlobalConf.GameConf.Port)
|
f7f4beb5
zhangqijia
新增grpc平滑关闭,修复crea...
|
94
|
return s.GrpcServer.Serve(lis)
|
ee23102d
zhangqijia
支持mongo, grpc接服务器
|
95
96
97
|
}
func (s *GameServer)Stop() {
|
f7f4beb5
zhangqijia
新增grpc平滑关闭,修复crea...
|
98
|
s.BasicServer.Stop()
|
ee23102d
zhangqijia
支持mongo, grpc接服务器
|
99
|
}
|