breakerinterceptor.go 1.0 KB

123456789101112131415161718192021222324252627282930313233
  1. package serverinterceptors
  2. import (
  3. "context"
  4. "github.com/tal-tech/go-zero/core/breaker"
  5. "github.com/tal-tech/go-zero/zrpc/internal/codes"
  6. "google.golang.org/grpc"
  7. )
  8. // StreamBreakerInterceptor is an interceptor that acts as a circuit breaker.
  9. func StreamBreakerInterceptor(srv interface{}, stream grpc.ServerStream, info *grpc.StreamServerInfo,
  10. handler grpc.StreamHandler) (err error) {
  11. breakerName := info.FullMethod
  12. return breaker.DoWithAcceptable(breakerName, func() error {
  13. return handler(srv, stream)
  14. }, codes.Acceptable)
  15. }
  16. // UnaryBreakerInterceptor is an interceptor that acts as a circuit breaker.
  17. func UnaryBreakerInterceptor() grpc.UnaryServerInterceptor {
  18. return func(ctx context.Context, req interface{}, info *grpc.UnaryServerInfo,
  19. handler grpc.UnaryHandler) (resp interface{}, err error) {
  20. breakerName := info.FullMethod
  21. err = breaker.DoWithAcceptable(breakerName, func() error {
  22. var err error
  23. resp, err = handler(ctx, req)
  24. return err
  25. }, codes.Acceptable)
  26. return resp, err
  27. }
  28. }