Ai
7 Star 23 Fork 31

go-course/go8

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
grpc.go 1.48 KB
一键复制 编辑 原始数据 按行查看 历史
Mr.Yu 提交于 2022-10-22 10:03 +08:00 . maudit添加grpc认证中间件
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
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/go-course/go8.git
git@gitee.com:go-course/go8.git
go-course
go8
go8
6a8978f41a84

搜索帮助