Blame view

actions/server.go 2.55 KB
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
  }