47 lines
1003 B
Go
47 lines
1003 B
Go
package grpc
|
|
|
|
import (
|
|
"context"
|
|
"flag"
|
|
"time"
|
|
|
|
v1 "go-common/app/service/bbq/recsys-recall/api/grpc/v1"
|
|
"go-common/app/service/bbq/recsys-recall/service"
|
|
"go-common/library/net/rpc/warden"
|
|
xtime "go-common/library/time"
|
|
|
|
"google.golang.org/grpc"
|
|
)
|
|
|
|
var (
|
|
_gRPCAddr string
|
|
)
|
|
|
|
func init() {
|
|
flag.StringVar(&_gRPCAddr, "grpc_addr", "0.0.0.0:9000", "default config path")
|
|
}
|
|
|
|
//New 生成rpc服务
|
|
func New(srv *service.Service) *warden.Server {
|
|
servConf := &warden.ServerConfig{
|
|
Addr: _gRPCAddr,
|
|
Timeout: xtime.Duration(2 * time.Second),
|
|
}
|
|
s := warden.NewServer(servConf)
|
|
s.Use(middleware())
|
|
v1.RegisterRecsysRecallServer(s.Server(), srv)
|
|
_, err := s.Start()
|
|
if err != nil {
|
|
panic("run server failed!" + err.Error())
|
|
}
|
|
return s
|
|
}
|
|
|
|
func middleware() grpc.UnaryServerInterceptor {
|
|
return func(ctx context.Context, req interface{}, info *grpc.UnaryServerInfo, handler grpc.UnaryHandler) (resp interface{}, err error) {
|
|
//call chain
|
|
resp, err = handler(ctx, req)
|
|
return
|
|
}
|
|
}
|