#rate-limiting #web-server #governor #actix

actix-governor

A rate-limiting middleware for actix-web backed by the governor crate

19 unstable releases (6 breaking)

0.8.0 Dec 12, 2024
0.7.0 Oct 25, 2024
0.6.0 Sep 16, 2024
0.5.0 Oct 4, 2023
0.2.3 Dec 31, 2020

#64 in HTTP server

Download history 1938/week @ 2024-09-21 2593/week @ 2024-09-28 3849/week @ 2024-10-05 3958/week @ 2024-10-12 4438/week @ 2024-10-19 4120/week @ 2024-10-26 4561/week @ 2024-11-02 3472/week @ 2024-11-09 3339/week @ 2024-11-16 3778/week @ 2024-11-23 4000/week @ 2024-11-30 4203/week @ 2024-12-07 4306/week @ 2024-12-14 1955/week @ 2024-12-21 1683/week @ 2024-12-28 2864/week @ 2025-01-04

11,493 downloads per month
Used in 7 crates

GPL-3.0-or-later

92KB
2K SLoC

CI Docs crates.io

Actix Governor

A middleware for actix-web that provides rate-limiting backed by governor.

Features:

  • Simple to use
  • High customizability
  • High performance
  • Robust yet flexible API

Example

use actix_governor::{Governor, GovernorConfigBuilder};
use actix_web::{web, App, HttpServer, Responder};

async fn index() -> impl Responder {
    "Hello world!"
}

#[actix_web::main]
async fn main() -> std::io::Result<()> {
    // Allow bursts with up to five requests per IP address
    // and replenishes two elements per second
    let governor_conf = GovernorConfigBuilder::default()
        .requests_per_second(2)
        .burst_size(5)
        .finish()
        .unwrap();

    HttpServer::new(move || {
        App::new()
            // Enable Governor middleware
            .wrap(Governor::new(&governor_conf))
            // Route hello world service
            .route("/", web::get().to(index))
    })
    .bind("127.0.0.1:8080")?
    .run()
    .await
}

Add this to your Cargo.toml:

[dependencies]
actix-governor = "0.6"

Dependencies

~18–30MB
~509K SLoC