Skip to content
This repository has been archived by the owner on Mar 7, 2022. It is now read-only.
/ token-bucket Public archive
forked from bbeck/token-bucket

๐ŸŽŸ Token bucket algorithm for rate-limiting

License

Notifications You must be signed in to change notification settings

thunken/token-bucket

ย 
ย 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 

History

55 Commits
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

Introduction

This library provides an implementation of a token bucket algorithm which is useful for providing rate limited access to a portion of code. The implementation provided is that of a "leaky bucket" in the sense that the bucket has a finite capacity and any added tokens that would exceed this capacity will "overflow" out of the bucket and be lost forever.

In this implementation the rules for refilling the bucket are encapsulated in a provided RefillStrategy instance. Prior to attempting to consume any tokens the refill strategy will be consulted to see how many tokens should be added to the bucket.

See also:

Usage

Using a token bucket is incredibly easy and is best illustrated by an example. Suppose you have a piece of code that polls a website and you would only like to be able to access the site once per second:

// Create a token bucket with a capacity of 1 token that refills at a fixed
// interval of 1 token/sec.
TokenBucket bucket = TokenBuckets.builder()
	.withCapacity(1)
	.withFixedIntervalRefillStrategy(1, 1, TimeUnit.SECONDS)
	.build();

// ...

while (true) {
	// Consume a token from the token bucket.  If a token is not available this
	// method will block until the refill strategy adds one to the bucket.
	bucket.consume(1);

	poll();
}

As another example suppose you wanted to rate limit the size response of a server to the client to 20 kb/sec but want to allow for a periodic burst rate of 40 kb/sec:

// Create a token bucket with a capacity of 40 kb tokens that refills at a fixed
// interval of 20 kb tokens per second
TokenBucket bucket = TokenBuckets.builder()
	.withCapacity(40960)
	.withFixedIntervalRefillStrategy(20480, 1, TimeUnit.SECONDS)
	.build();

// ...

while (true) {
	String response = prepareResponse();

	// Consume tokens from the bucket commensurate with the size of the response
	bucket.consume(response.length());

	send(response);
}

Maven Setup

The library is distributed through Maven and Jiptack. Just include it as a dependency in your pom.xml.

Add the JitPack repository to your build file:

	<repositories>
		<repository>
		    <id>jitpack.io</id>
		    <url>https://jitpack.io</url>
		</repository>
	</repositories>

Add the dependency:

	<dependency>
	    <groupId>com.github.thunken</groupId>
	    <artifactId>token-bucket</artifactId>
	    <version>v2.0.1</version>
	</dependency>

License

Copyright 2012โ€“2015 Brandon Beck, 2017 Thunken Inc. Licensed under the Apache Software License, Version 2.0: http://www.apache.org/licenses/LICENSE-2.0.

About

๐ŸŽŸ Token bucket algorithm for rate-limiting

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Java 100.0%