|
|
|
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, 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
|
|
|
|
}
|