package server import ( v1 "github.com/go-kratos/kratos/examples/blog/api/blog/v1" "github.com/go-kratos/kratos/examples/blog/internal/conf" "github.com/go-kratos/kratos/examples/blog/internal/service" "github.com/go-kratos/kratos/v2/log" "github.com/go-kratos/kratos/middleware/logging/v2" "github.com/go-kratos/kratos/middleware/recovery/v2" "github.com/go-kratos/kratos/middleware/tracing/v2" "github.com/go-kratos/kratos/middleware/validate/v2" "github.com/go-kratos/kratos/v2/transport/grpc" "go.opentelemetry.io/otel/trace" ) // NewGRPCServer new a gRPC server. func NewGRPCServer(c *conf.Server, logger log.Logger, tracer trace.TracerProvider, blog *service.BlogService) *grpc.Server { var opts = []grpc.ServerOption{ grpc.Middleware( recovery.Recovery(), tracing.Server(tracing.WithTracerProvider(tracer)), logging.Server(logger), validate.Validator(), ), } if c.Grpc.Network != "" { opts = append(opts, grpc.Network(c.Grpc.Network)) } if c.Grpc.Addr != "" { opts = append(opts, grpc.Address(c.Grpc.Addr)) } if c.Grpc.Timeout != nil { opts = append(opts, grpc.Timeout(c.Grpc.Timeout.AsDuration())) } srv := grpc.NewServer(opts...) v1.RegisterBlogServiceServer(srv, blog) return srv }