Documentation ¶
Overview ¶
Package circuitbreaker is an adaptive circuit breaker library, support for use in gin middleware and grpc interceptors.
Index ¶
Constants ¶
const ( // StateOpen when circuit breaker open, request not allowed, after sleep // some duration, allow one single request for testing the health, if ok // then state reset to closed, if not continue the step. StateOpen int32 = iota // StateClosed when circuit breaker closed, request allowed, the breaker // calc the succeed ratio, if request num greater request setting and // ratio lower than the setting ratio, then reset state to open. StateClosed )
Variables ¶
var ErrNotAllowed = errors.New("circuitbreaker: not allowed for circuit open")
ErrNotAllowed error not allowed.
Functions ¶
This section is empty.
Types ¶
type Breaker ¶
type Breaker struct {
// contains filtered or unexported fields
}
Breaker is a sre CircuitBreaker pattern.
type CircuitBreaker ¶
type CircuitBreaker interface { Allow() error MarkSuccess() MarkFailed() }
CircuitBreaker is a circuit breaker.
func NewBreaker ¶
func NewBreaker(opts ...Option) CircuitBreaker
NewBreaker return a sreBresker with options
type Option ¶
type Option func(*options)
Option is sre breaker option function.
func WithBucket ¶
WithBucket set the bucket number in a window duration.
func WithRequest ¶
WithRequest with the minimum number of requests allowed.
func WithSuccess ¶
WithSuccess with the K = 1 / Success value of sre breaker, default success is 0.5 Reducing the K will make adaptive throttling behave more aggressively, Increasing the K will make adaptive throttling behave less aggressively.
func WithWindow ¶
WithWindow with the duration size of the statistical window.