Skip to content

Latest commit

 

History

History
37 lines (23 loc) · 1.06 KB

README.md

File metadata and controls

37 lines (23 loc) · 1.06 KB

Description Build Status

ratelimiter is a simple golang implementation of a thread safe, basic rate limiter.

Usage

Creating a Rate Limiter

To create a rate limiter, simply:

limiter := NewRateLimiter()
limiter.SetRate(5000.0) // 5000 Permit per second

Using The Rate Limiter

There are two ways to aquire permits:

  • Blocking
  • Blocking with Timeout

For the basic blocking:

limiter.Aquire(1) // aquires 1 permit. Will block the thread until it is allowed to proceed

For the timeout blocking:

limiter.TryAquire(2, 0)    // aquires 2 permit with noblocking
limiter.TryAquire(2, 3000) // aquires 2 permit, and max timeout is 3000us

If TryAquire can aquire it's permits within the specified time (from now), it will block as long as necessary by the rate limiter, and then return true when it has aquired the permits. If it cannot aquire those permits within the specified time, then it will return IMMEDIATELY, with a value of false.