mirror of
https://github.com/minio/minio.git
synced 2025-02-18 17:12:31 -05:00
35 lines
1.0 KiB
Markdown
35 lines
1.0 KiB
Markdown
|
circuit-breaker
|
||
|
===============
|
||
|
|
||
|
[data:image/s3,"s3://crabby-images/8c346/8c3463301d9549e73ec94fc9b390b8634d69ceb7" alt="Build Status"](https://travis-ci.org/eapache/go-resiliency)
|
||
|
[data:image/s3,"s3://crabby-images/d4551/d4551027d16862ee392d3afa67c6c13db45a141e" alt="GoDoc"](https://godoc.org/github.com/eapache/go-resiliency/breaker)
|
||
|
[data:image/s3,"s3://crabby-images/df32e/df32e50743bea96cb47af55ee64518d091abfb5f" alt="Code of Conduct"](https://eapache.github.io/conduct.html)
|
||
|
|
||
|
The circuit-breaker resiliency pattern for golang.
|
||
|
|
||
|
Creating a breaker takes three parameters:
|
||
|
- error threshold (for opening the breaker)
|
||
|
- success threshold (for closing the breaker)
|
||
|
- timeout (how long to keep the breaker open)
|
||
|
|
||
|
```go
|
||
|
b := breaker.New(3, 1, 5*time.Second)
|
||
|
|
||
|
for {
|
||
|
result := b.Run(func() error {
|
||
|
// communicate with some external service and
|
||
|
// return an error if the communication failed
|
||
|
return nil
|
||
|
})
|
||
|
|
||
|
switch result {
|
||
|
case nil:
|
||
|
// success!
|
||
|
case breaker.ErrBreakerOpen:
|
||
|
// our function wasn't run because the breaker was open
|
||
|
default:
|
||
|
// some other error
|
||
|
}
|
||
|
}
|
||
|
```
|