npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

circuitbreaker-lambda

v0.0.1

Published

Module for circuit breaker pattern in AWS Lambda

Downloads

8

Readme

Circuit breaker for AWS Lambda - circuitbreaker-lambda

Description

circuitbreaker-lambda is a basic Node module for using the circuit breaker pattern in AWS Lambda (https://aws.amazon.com/lambda) and general async functions. It relies on a pass/fail assumption. Thresholds and timeout values are configurable and there is support for using a fallback function for graceful degradation. State and counters for the circuit breaker is stored in an Amazon DynamoDB table.

circuitbreaker-lambda diagram

How to install and configure

  1. Install circuitbreaker-lambda module using NPM.
npm install circuitbreaker-lambda
  1. Import the circuitbreaker-lambda module in your Lambda function code.
const CircuitBreaker = require('circuitbreaker-lambda')
  1. Add options for the circuit breaker. This is optional and if all or single options are missing the circuit breaker will revert to defaults.
const options = {
  fallback: fallbackFunction,
  failureThreshold: 5,
  successThreshold: 2,
  timeout: 10000
}
  1. Instantiate the circuit breaker with the function and optional options.
const circuitBreaker = new CircuitBreaker(unreliableFunction, options)
  1. Add the fire function for the circuit breaker.
await circuitBreaker.fire()
  1. Create an Amazon DynamoDB table with a single attribute primary key. The primary key should be a String with a value of id.
aws dynamodb create-table \
    --table-name circuitbreakerLambdaTable \
    --attribute-definitions AttributeName=id,AttributeType=S \
    --key-schema AttributeName=id,KeyType=HASH \
    --billing-mode PAY_PER_REQUEST
  1. Give the Lambda function GetItem and UpdateItem permissions to the Lambda table.
{
  "Action": [
    "dynamodb:GetItem",
    "dynamodb:UpdateItem"
  ],
  "Resource": "arn:aws:dynamodb:eu-west-1:*:table/circuitbreakerLambdaTable",
  "Effect": "Allow"
}
  1. Add an environment variable to your Lambda function with the key CIRCUITBREAKER_TABLE and the value set to the name of your table in Amazon DynamoDB.
  2. Try it out!

Circuit breaker states

These are the different states for circuitbreaker-lambda.

  • CLOSED: Everything is working normally and all calls pass through to the circuit breaker
  • OPEN: Requests fail for a set amount of time. Fallback is used if configured.
  • HALF: Requests are let through to test the stability of the call. Fallback is used if configured.

State transitions

These are the ways circuitbreaker-lambda transitions between states.

  • CLOSED to OPEN: When failureCount greater than or equal to failureThreshold.
  • OPEN to HALF: When Date.now() greater than or equal to nextAttempt.
  • HALF to OPEN: When failure occurs in HALF state.
  • HALF to CLOSED: When successCount greater than or equal to successThreshold.

Options

You can optionally add options and control the behavior of circuitbreaker-lambda.

const options = {
  fallback: fallbackFunction,
  failureThreshold: 5,
  successThreshold: 2,
  timeout: 10000
}
  • fallback: Add this option if you wish to use a fallback function in case of failure. Use the name of your function.
  • failureThreshold: The number of failed attempts before the circuit breaker changes state to OPEN.
  • successThreshold The number of successful attempts while the state is HALF before the circuit breaker changes state to CLOSED.
  • timeout The timeout after the circuit breaker changed state to OPEN before it will attempt the regular function call again.

These are the default values used if options aren't defined.

const defaults = {
  fallback: null,
  failureThreshold: 5,
  successThreshold: 2,
  timeout: 10000
}

Example

In the subfolder example is a simple Serverless Framework template and an AWS SAM template which will install an example application with a Lambda function and a DynamoDB table. The example Lambda function has circuitbreaker-lambda installed, an example unreliableFunction which fails about 60 percent of the time (Math.random() < 0.6), and an example fallbackFunction.

Serverless Framework Example

npm install
sls deploy

AWS SAM Example

npm install
sam build
sam deploy --guided

Notes

Inspired by Michael Nygard's book Release it! (https://www.amazon.com/gp/product/0978739213), Martin Fowler's article on the circuit breaker (https://martinfowler.com/bliki/CircuitBreaker.html), and Mark Michon's post on building a Node.js circuit breaker (https://blog.bearer.sh/build-a-circuit-breaker-in-node-js/).

Changelog

2020-10-10 v0.0.1

  • Initial release

Contributors

Gunnar Grosch - GitHub | Twitter | LinkedIn