go-zero/core/breaker/breakers.go

102 lines
2.8 KiB
Go
Raw Normal View History

2020-07-26 17:09:05 +08:00
package breaker
2024-04-18 20:58:36 +08:00
import (
"context"
"sync"
)
2020-07-26 17:09:05 +08:00
var (
lock sync.RWMutex
breakers = make(map[string]Breaker)
)
// Do calls Breaker.Do on the Breaker with given name.
2020-07-26 17:09:05 +08:00
func Do(name string, req func() error) error {
return do(name, func(b Breaker) error {
return b.Do(req)
})
}
2024-04-18 20:58:36 +08:00
// DoCtx calls Breaker.DoCtx on the Breaker with given name.
func DoCtx(ctx context.Context, name string, req func() error) error {
return do(name, func(b Breaker) error {
return b.DoCtx(ctx, req)
})
}
// DoWithAcceptable calls Breaker.DoWithAcceptable on the Breaker with given name.
2020-07-26 17:09:05 +08:00
func DoWithAcceptable(name string, req func() error, acceptable Acceptable) error {
return do(name, func(b Breaker) error {
return b.DoWithAcceptable(req, acceptable)
})
}
2024-04-18 20:58:36 +08:00
// DoWithAcceptableCtx calls Breaker.DoWithAcceptableCtx on the Breaker with given name.
func DoWithAcceptableCtx(ctx context.Context, name string, req func() error,
acceptable Acceptable) error {
return do(name, func(b Breaker) error {
return b.DoWithAcceptableCtx(ctx, req, acceptable)
})
}
// DoWithFallback calls Breaker.DoWithFallback on the Breaker with given name.
func DoWithFallback(name string, req func() error, fallback Fallback) error {
2020-07-26 17:09:05 +08:00
return do(name, func(b Breaker) error {
return b.DoWithFallback(req, fallback)
})
}
2024-04-18 20:58:36 +08:00
// DoWithFallbackCtx calls Breaker.DoWithFallbackCtx on the Breaker with given name.
func DoWithFallbackCtx(ctx context.Context, name string, req func() error, fallback Fallback) error {
return do(name, func(b Breaker) error {
return b.DoWithFallbackCtx(ctx, req, fallback)
})
}
// DoWithFallbackAcceptable calls Breaker.DoWithFallbackAcceptable on the Breaker with given name.
func DoWithFallbackAcceptable(name string, req func() error, fallback Fallback,
2020-07-26 17:09:05 +08:00
acceptable Acceptable) error {
return do(name, func(b Breaker) error {
return b.DoWithFallbackAcceptable(req, fallback, acceptable)
})
}
2024-04-18 20:58:36 +08:00
// DoWithFallbackAcceptableCtx calls Breaker.DoWithFallbackAcceptableCtx on the Breaker with given name.
func DoWithFallbackAcceptableCtx(ctx context.Context, name string, req func() error,
fallback Fallback, acceptable Acceptable) error {
return do(name, func(b Breaker) error {
return b.DoWithFallbackAcceptableCtx(ctx, req, fallback, acceptable)
})
}
// GetBreaker returns the Breaker with the given name.
2020-07-26 17:09:05 +08:00
func GetBreaker(name string) Breaker {
lock.RLock()
b, ok := breakers[name]
lock.RUnlock()
if ok {
return b
}
lock.Lock()
2020-09-30 16:50:02 +08:00
b, ok = breakers[name]
if !ok {
b = NewBreaker(WithName(name))
breakers[name] = b
}
lock.Unlock()
2020-09-30 17:47:56 +08:00
2020-07-26 17:09:05 +08:00
return b
}
// NoBreakerFor disables the circuit breaker for the given name.
func NoBreakerFor(name string) {
2020-07-26 17:09:05 +08:00
lock.Lock()
breakers[name] = NopBreaker()
2020-07-26 17:09:05 +08:00
lock.Unlock()
}
func do(name string, execute func(b Breaker) error) error {
2020-09-30 16:50:02 +08:00
return execute(GetBreaker(name))
2020-07-26 17:09:05 +08:00
}