通用包
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
utils/interceptor/v1/README.md

116 lines
2.8 KiB

# interceptor-通用grpcInterceptor
## 说明
> grpc请求和响应拦截器
> - server
> - server原样返回业务错误,正式服其它错误统一返回InternalServerError
> - client
> - client默认转换server的所有error为kratos的error,方便bff原样返回
## 使用示例
### client
```go
package data
import (
"context"
grpc2 "gitea.drugeyes.vip/pharnexbase/utils/interceptor/v1/grpc"
"github.com/go-kratos/kratos/v2/middleware/circuitbreaker"
"github.com/go-kratos/kratos/v2/middleware/tracing"
"github.com/go-kratos/kratos/v2/transport/grpc"
"github.com/google/wire"
user "user-center-front/api/user/v2"
"user-center-front/internal/conf"
)
// ProviderSet is data providers.
var ProviderSet = wire.NewSet(
NewData,
NewUserService,
)
// Data .
type Data struct {
User user.UserCenterClient
}
// NewData .
func NewData(userServer user.UserCenterClient) *Data {
return &Data{
User: userServer,
}
}
func NewUserService(c *conf.Bootstrap) user.UserCenterClient {
grpcInterceptor := grpc2.NewInterceptor(c.Env, nil)
conn, err := grpc.DialInsecure(
context.Background(),
grpc.WithEndpoint(c.Service.GetUser()),
grpc.WithTimeout(0),
grpc.WithMiddleware(
tracing.Client(), // 链路追踪
circuitbreaker.Client(), // 熔断器
),
// 拦截器
grpc.WithUnaryInterceptor(grpcInterceptor.UnaryClientInterceptor()),
)
if err != nil {
panic(err)
}
return user.NewUserCenterClient(conn)
}
```
### server
```go
package server
import (
"github.com/go-kratos/kratos/v2/log"
"github.com/go-kratos/kratos/v2/middleware/logging"
"github.com/go-kratos/kratos/v2/middleware/ratelimit"
"github.com/go-kratos/kratos/v2/middleware/recovery"
"github.com/go-kratos/kratos/v2/middleware/validate"
"github.com/go-kratos/kratos/v2/transport/grpc"
grpc2 "gitea.drugeyes.vip/pharnexbase/utils/interceptor/v1/grpc"
v2 "user-center-v2/api/user/v2"
"user-center-v2/internal/conf"
pkgLog "user-center-v2/internal/pkg/log"
"user-center-v2/internal/service"
)
// NewGRPCServer new a gRPC server.
func NewGRPCServer(c *conf.Bootstrap, userService *service.UserCenterService, logger log.Logger) *grpc.Server {
grpcInterceptor := grpc2.NewInterceptor(c.Env, v2.ErrorReason_value)
var opts = []grpc.ServerOption{
grpc.Middleware(
recovery.Recovery(),
pkgLog.Trace(),
ratelimit.Server(),
logging.Server(logger),
validate.Validator(),
),
// 拦截器
grpc.UnaryInterceptor(grpcInterceptor.UnaryServerInterceptor()),
}
if c.Server.Grpc.Network != "" {
opts = append(opts, grpc.Network(c.Server.Grpc.Network))
}
if c.Server.Grpc.Addr != "" {
opts = append(opts, grpc.Address(c.Server.Grpc.Addr))
}
if c.Server.Grpc.Timeout != nil {
opts = append(opts, grpc.Timeout(c.Server.Grpc.Timeout.AsDuration()))
}
srv := grpc.NewServer(opts...)
v2.RegisterUserCenterServer(srv, userService)
return srv
}
```