An Interactive Guide to Rate Limiting

3 weeks ago 1

Introduction

Rate limiting is a must have strategy in every back-end app. It prevent one user from overusing a resource and degrading the quality of service for other users. Here are some benefits of rate limiting

  • It presents resource starvation

  • Reduces server hosting cost

  • Provides basic protection against DDoS

I have made four interactive app that let’s you play around with common rate limiting algorithms.

Token bucket

Working:

  • A bucket holds fixed number tokens

  • Tokens are added to bucket at fixed rate

  • When a request comes in:

    • If a token is available, it’s removed from the bucket and the request is allowed.

    • If no tokens are available, the request is rejected or delayed.

  • Allows for occasional short burst if tokens are available

I have created an app that let’s you play with leaky bucket algorithm.

Leaky bucket

Working

  • Think of it as a bucket leaking at a fixed rate

  • Incoming requests are added to the bucket

  • Requests are processed (or "leak") at a constant rate

  • If the bucket is full when a new request arrives, the request is dropped

  • Smooths out bursts; outputs requests at a steady rate

    I have made an app that let’s you play with leaky bucket algorithm.

Fixed window counter

Working:

  • Time is divided into fixed size windows (e.g., 1 minute)

  • A counter tracks the number of requests per client/IP in the current window

  • If the count exceeds the limit, further requests are rejected until the next window

  • Simple and efficient, but allows burst traffic spike at end/start

    I have created an app that let’s you play with fixed bucket algorithm.

Sliding window counter

Working:

  • Keeps a timestamped log of each request

  • When a request comes in, logs are checked to count how many requests were made in the last X seconds

  • If under the limit, the request is allowed and logged; otherwise, it’s rejected

    I have created an app that let’s you play with sliding bucket algorithm.

    %%[sliding-window]

    Token bucket

    Working:

    • A bucket holds fixed number tokens

    • Tokens are added to bucket at fixed rate

    • When a request comes in:

      • If a token is available, it’s removed from the bucket and the request is allowed.

      • If no tokens are available, the request is rejected or delayed.

    • Allows for occasional short burst if tokens are available

      I have created an app that let’s you play with leaky bucket algorithm.

Read Entire Article