Chaos Monkey Alternatives - Spring Boot

4 minute read

Chaos Monkey for Spring Boot

Chaos Monkey for Spring Boot is an open-source tool written in Java that is installed as either an internal or external dependency at startup. Spring Boot for Chaos Monkey can perform three types of Assaults: Latency, Exception, and KillApplication. Assaults are triggered based on Watcher components that monitor @Controller, @RestController, @Service, @Repository, and @Component Spring Boot annotations.

A Watcher can only be triggered by public method calls, which can then execute a configured Assault. A Latency Assault adds random latency to the request, an Exception Assault randomly throws a Runtime Exception, and a KillApplication Assault kills the Spring Boot application.

A few minimal Assault and Watcher settings can be configured via chaos.monkey properties, as listed below.

Property Description Type Default
chaos.monkey.enabled Toggle Chaos Monkey Boolean FALSE
chaos.monkey.assaults.level Assault severity Integer (1-10) 5
chaos.monkey.assaults.latencyRangeStart Minimum latency (MS) added to request Integer 3000
chaos.monkey.assaults.latencyRangeEnd Maximum latency (MS) added to request Integer 15000
chaos.monkey.assaults.latencyActive Toggle Latency Assault Boolean TRUE
chaos.monkey.assaults.exceptionsActive Toggle Exception Assault Boolean FALSE
chaos.monkey.assaults.killApplicationActive Toggle KillApplication Assault Boolean FALSE
chaos.monkey.watcher.controller Toggle Controller Watcher Boolean FALSE
chaos.monkey.watcher.restController Toggle RestController Watcher Boolean FALSE
chaos.monkey.watcher.service Toggle Service Watcher Boolean TRUE
chaos.monkey.watcher.repository Toggle Repository Watcher Boolean FALSE
chaos.monkey.watcher.component Toggle Component Watcher Boolean FALSE

Most are self-explanatory, but the Assault severity level property (chaos.monkey.assaults.level) actually determines two things: The number of requests between Assaults, and also how many Assaults will occur at that time. Thus, a default level of 5 means that 5 Assaults will occur on every fifth request.

Configuration properties can be changed at runtime via the HTTP endpoints. For example, sending JSON configuration data to the /chaosmonkey/assaults endpoint can be used to modify future Assault configurations.

{
  "level": 2,
  "latencyRangeStart": 2500,
  "latencyRangeEnd": 7500,
  "latencyActive": true,
  "exceptionsActive": true,
  "killApplicationActive": true,
  "restartApplicationActive": true,
  "watchedCustomServices": [ "com.example.chaos.monkey.chaosdemo.controller.HelloController.sayHello" ]
}

Check out the reference guide for more information on getting Chaos Monkey for Spring Boot up and running.

Injecting Failure in Spring Boot Applications with Gremlin

Gremlin’s Failure as a Service makes it easy to execute thoughtful Chaos Experiments within your standalone Spring-based applications, including those built with Spring Boot. Rather than inject itself directly into your application’s Java code Gremlin performs attacks against the instances powering your application. Gremlin can execute a wide range of attacks including draining disk space, hogging CPU and memory, overloading IO, manipulating network traffic, terminating instances, and more.

Running your first Chaos Experiment with Gremlin is as simple as signing up for a Gremlin account, installing the Gremlin daemon on the targeted instances, and then launching attacks via either the web UI or API. Check out this installation tutorial to get started!

Chaos Engineering with Fabric8 and Spring Boot

The Fabric8 development platform has first-class support for building Spring Boot applications and comes with a built-in Chaos Monkey app. The Fabric8 Chaos Monkey is capable of deleting pods within Kubernetes/OpenShift applications.

To get started in the Fabric8 console navigate to Apps, click Run…, select the Chaos Monkey app, and run it. Once the Chaos Monkey app is running within your Fabric8 Sprint Boot deployment you can configure Chaos Monkey using a few options.

  • Chaos Monkey Excludes: A comma-separated regex pattern list indicating which pods are not eligible for deletion.
  • Chaos Monkey Includes: A comma-separated regex pattern list indicating which pods are eligible for deletion.
  • Chaos Monkey Frequency Seconds: The delay between each pod deletion.

You can also optionally run the ChatOps app and set the Chaos Monkey Room configuration option to indicate which chat room Chaos Monkey should communicate with. The Chaos Monkey app will then post notifications of its actions in chat.

# CHAT OUTPUT EXAMPLE
added replicationController chaos-monkey
added pod chaos-monkey-2fahv
Chaos Monkey is starting in namespace default with include patterns 'fabric8mq*' exclude patterns 'chat*' and a kill frequency of 30 seconds.  Here I come!
Chaos Monkey killed pod fabric8mq-consumer-7hwe1 in namespace default

Have a look at the official documentation for more details.