Skip to content

Guard external service access with a Circuit Breaker based on the book "Release It" (Michael Nygard)

Notifications You must be signed in to change notification settings

oluies/Circuit-Breaker-for-Scala

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 

Repository files navigation

This is a Scala Implementation of the Circuit Breaker state machine mentioned in the book Release It

I used the GoF State Machine pattern (like Ken DeLong), implemented it in Scala and added some factory stuff.

Use it like this

. . .
addCircuitBreaker("test", CircuitBreakerConfiguration(100,10))
. . .

class Test extends UsingCircuitBreaker {
  def myMethodWorkingFine = {
    withCircuitBreaker("test") {
      . . . 
    }
  }

  def myMethodDoingWrong = {
    withCircuitBreaker("test") {
      throw new java.lang.IllegalArgumentException
    }
  }
}

I will add maven pom and addional test specs (see src/TestCircuitBreaker.scala) later.

About

Guard external service access with a Circuit Breaker based on the book "Release It" (Michael Nygard)

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Scala 100.0%