1 Star 0 Fork 0

谈子文/keyauth-tz

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
grpc.go 2.51 KB
一键复制 编辑 原始数据 按行查看 历史
谈子文 提交于 2023-10-25 15:11 . 优化
package protocol
import (
"context"
"github.com/infraboard/mcenter/apps/instance"
"github.com/infraboard/mcenter/client/rpc"
"github.com/infraboard/mcenter/client/rpc/lifecycle"
"net"
"time"
"google.golang.org/grpc"
"github.com/infraboard/mcube/app"
"github.com/infraboard/mcube/grpc/middleware/recovery"
"github.com/infraboard/mcube/logger"
"github.com/infraboard/mcube/logger/zap"
"gitee.com/talk-about-articles/keyauth-tz/conf"
)
// NewGRPCService todo
func NewGRPCService() *GRPCService {
log := zap.L().Named("GRPC Service")
rc := recovery.NewInterceptor(recovery.NewZapRecoveryHandler())
grpcServer := grpc.NewServer(grpc.ChainUnaryInterceptor(
rc.UnaryServerInterceptor(),
))
// 控制GRPC启动其他服务,比如注册中心,或者心跳
ctx, cancel := context.WithCancel(context.Background())
return &GRPCService{
svr: grpcServer,
l: log,
c: conf.C(),
ctx: ctx,
cancel: cancel,
}
}
// GRPCService grpc服务
type GRPCService struct {
svr *grpc.Server
l logger.Logger
c *conf.Config
ctx context.Context
cancel context.CancelFunc
// 控制实例上线和下线
lf lifecycle.Lifecycler
}
// Start 启动GRPC服务
func (s *GRPCService) Start() {
// 装载所有GRPC服务
app.LoadGrpcApp(s.svr)
// 启动HTTP服务
lis, err := net.Listen("tcp", s.c.App.GRPC.Addr())
if err != nil {
s.l.Errorf("listen grpc tcp conn error, %s", err)
return
}
// 1. 理论上 我们需要等待GRPC服务启动成功后,才注册
// 但是 GRPC server 没有提供成功时的回调
// 假设GPRC Server 1秒能正常启动
time.AfterFunc(1*time.Second, s.registry)
s.l.Infof("GRPC 服务监听地址: %s", s.c.App.GRPC.Addr())
if err := s.svr.Serve(lis); err != nil {
if err == grpc.ErrServerStopped {
s.l.Info("service is stopped")
}
s.l.Error("start grpc service error, %s", err.Error())
return
}
}
// Stop 启动GRPC服务
func (s *GRPCService) Stop() error {
// 提前 剔除注册中心的地址
if s.lf != nil {
if err := s.lf.UnRegistry(s.ctx); err != nil {
s.l.Errorf("unregistry error, %s", err)
} else {
s.l.Info("unregistry success")
}
}
s.svr.GracefulStop()
return nil
}
func (s *GRPCService) registry() {
//1. 获取 mcenter sdk 实例
// sdk 提供注册方法
req := instance.NewRegistryRequest()
req.Address = s.c.App.GRPC.Addr()
lf, err := rpc.C().Registry(s.ctx, req)
if err != nil {
s.l.Errorf("registry to mcenter error, %s", err)
return
}
s.l.Infof("registry to mcenter success")
// 注销时需要使用
s.lf = lf
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/talk-about-articles/keyauth-tz.git
git@gitee.com:talk-about-articles/keyauth-tz.git
talk-about-articles
keyauth-tz
keyauth-tz
v1.0.17

搜索帮助