Ai
1 Star 0 Fork 0

csingo/cServer

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
GRPC.go 1.65 KB
一键复制 编辑 原始数据 按行查看 历史
cxy1620541673 提交于 2025-02-18 13:38 +08:00 . update
package cServer
import (
"context"
"fmt"
"net"
"reflect"
"google.golang.org/grpc"
"gitee.com/csingo/cCommon"
"gitee.com/csingo/cContext"
"gitee.com/csingo/cLog"
)
func startGRPC() {
if !server_config.GrpcServer.Enable {
return
}
// 监听端口
conn, err := net.Listen("tcp", fmt.Sprintf(":%d", server_config.GrpcServer.Port))
if err != nil {
cLog.WithContext(nil, map[string]interface{}{
"source": "cServer.startGRPC",
"err": err.Error(),
}).Fatal("GRPC 服务端口监听异常")
}
// 注册路由
server := grpc.NewServer(grpc.UnaryInterceptor(newRouteUnaryServerInterceptor()))
container.Range(func(instance any) {
if reflect.TypeOf(instance).Implements(reflect.TypeOf((*GrpcServiceInterface)(nil)).Elem()) {
desc := instance.(GrpcServiceInterface).GrpcServiceDesc()
server.RegisterService(desc, instance)
}
})
cLog.WithContext(nil, map[string]interface{}{
"source": "cServer.startGRPC",
"port": server_config.GrpcServer.Port,
}).Info("启动 GRPC 服务")
// 启动服务
if err = server.Serve(conn); err != nil {
cLog.WithContext(nil, map[string]interface{}{
"source": "cServer.startGRPC",
"err": err.Error(),
}).Fatal("GRPC 服务启动失败")
}
}
func newRouteUnaryServerInterceptor() grpc.UnaryServerInterceptor {
return func(ctx context.Context, req any, info *grpc.UnaryServerInfo, handler grpc.UnaryHandler) (resp any, err error) {
// context 转换为 gin.Context
newCtx := cContext.GrpcToGin(ctx)
newCtx.Set(cCommon.XIndex_RequestType, "GRPC")
// 处理service
resp, err = handler(newCtx, req)
if err != nil {
return
}
newCtx.Set(cCommon.XIndex_ResponseData, resp)
return
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/csingo/cServer.git
git@gitee.com:csingo/cServer.git
csingo
cServer
cServer
v0.4.27

搜索帮助