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/v2/middleware/logging" "github.com/go-kratos/kratos/v2/middleware/recovery" "github.com/go-kratos/kratos/v2/middleware/tracing" "github.com/go-kratos/kratos/v2/middleware/validate" "github.com/go-kratos/kratos/v2/transport/grpc" "go.opentelemetry.io/otel/trace" ) // NewGRPCServer new a gRPC server. func NewGRPCServer(c *conf.Server, tracer trace.TracerProvider, blog *service.BlogService) *grpc.Server { var opts = []grpc.ServerOption{ grpc.Middleware( tracing.Server(tracing.WithTracerProvider(tracer)), logging.Server(log.DefaultLogger), recovery.Recovery(), validate.Validator(v1.BlogService_ServiceDesc.ServiceName+".grpc"), ), } 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 }