Ai
7 Star 17 Fork 27

go-course/go9

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
grpc.go 1.29 KB
一键复制 编辑 原始数据 按行查看 历史
Mr.Yu 提交于 2023-03-18 12:10 +08:00 . 资源管理业务设计
package protocol
import (
"net"
"gitee.com/go-course/go9/projects/devcloud/cmdb/conf"
"google.golang.org/grpc"
"gitee.com/go-course/go9/projects/devcloud/cmdb/common/logger"
"github.com/infraboard/mcube/app"
"github.com/infraboard/mcube/grpc/middleware/recovery"
)
// NewGRPCService todo
func NewGRPCService() *GRPCService {
rc := recovery.NewInterceptor(recovery.NewZapRecoveryHandler())
grpcServer := grpc.NewServer(grpc.ChainUnaryInterceptor(
rc.UnaryServerInterceptor(),
))
return &GRPCService{
svr: grpcServer,
c: conf.C(),
}
}
// GRPCService grpc服务
type GRPCService struct {
svr *grpc.Server
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 {
logger.L().Debug().Msgf("listen grpc tcp conn error, %s", err)
return
}
logger.L().Info().Msgf("GRPC 服务监听地址: %s", s.c.App.GRPC.Addr())
if err := s.svr.Serve(lis); err != nil {
if err == grpc.ErrServerStopped {
logger.L().Info().Msg("service is stopped")
}
logger.L().Error().Msgf("start grpc service error, %s", err.Error())
return
}
}
// Stop 启动GRPC服务
func (s *GRPCService) Stop() error {
s.svr.GracefulStop()
return nil
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/go-course/go9.git
git@gitee.com:go-course/go9.git
go-course
go9
go9
2c311f48cd84

搜索帮助