代码拉取完成,页面将自动刷新
package protocol
import (
"net"
"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/go-course/go8/projects/devcloud/maudit/conf"
"gitee.com/go-course/go8/projects/devcloud/mcenter/client/rpc/auth"
)
// NewGRPCService todo
func NewGRPCService() *GRPCService {
log := zap.L().Named("GRPC Service")
rc := recovery.NewInterceptor(recovery.NewZapRecoveryHandler())
grpcServer := grpc.NewServer(grpc.ChainUnaryInterceptor(
rc.UnaryServerInterceptor(),
// 需要提供加载mcenter服务的客户端
auth.GrpcAuthUnaryServerInterceptor(),
))
return &GRPCService{
svr: grpcServer,
l: log,
c: conf.C(),
}
}
// GRPCService grpc服务
type GRPCService struct {
svr *grpc.Server
l logger.Logger
c *conf.Config
}
// 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
}
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 {
s.svr.GracefulStop()
return nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。