Skip to content

chenyanchen/breaker

Repository files navigation

What is this?

Circuit Breaker in Go.

Why use it?

A grace way to Handling Overload in client-side.

How does it work?

There are only one implementation of Circuit Breaker, it is from Google SRE.

How to use it?

The abstract of Breaker interface is clear, it only cares about:

  • the dependency is available or not

Not care about:

  • specific errors
  • fallback strategies
  • telemetry

There are some examples to show how to use it:

Benchmark

❯ go test -bench=. -benchmem
goos: darwin
goarch: arm64
pkg: github.com/chenyanchen/breaker
BenchmarkGoogleBreaker_Do-8      5794507               249.1 ns/op             0 B/op          0 allocs/op
PASS
ok      github.com/chenyanchen/breaker  1.658s