ntex-ratelimiter
A rate limiting middleware for the ntex web framework.
Installation
tokio(default): Enable Tokio runtime supportasync-std: Enable async-std runtime supportjson(default): Enable JSON serialization for error responses
[]
# Default features (tokio + json)
= "^0"
# With async-std instead of tokio
= { = "^0", = false, = ["async-std", "json"] }
# Minimal build without JSON support
= { = "^0", = false, = ["tokio"] }
Usage
The primary components are RateLimiter and RateLimit.
RateLimiter: Manages the rate limiting logic and state. You create an instance of this, often shared across your application.RateLimit: Thentexmiddleware that wraps your services and applies the rate limiting rules defined by aRateLimiterinstance.
Quick Start
use web;
use ;
async
Advanced Configuration
For more control over the rate limiter behavior:
use ;
use Duration;
let config = RateLimiterConfig ;
let limiter = with_config;
// Get statistics
let stats = limiter.stats;
println!;
How It Works
This middleware uses the token bucket algorithm for rate limiting:
- Each client IP gets a token bucket with a configured capacity
- Tokens are consumed on each request
- Tokens are refilled at a constant rate based on the time window
- When the bucket is empty, requests are rate limited
Client IP Detection
The middleware intelligently extracts client IPs from:
X-Forwarded-Forheader (first IP in comma-separated list)X-Real-IPheader- Connection remote address (fallback)
This ensures accurate rate limiting even behind proxies and load balancers.
Response Headers
The middleware adds these headers to all responses:
| Header | Description |
|---|---|
x-ratelimit-remaining |
Number of requests remaining in current window |
x-ratelimit-limit |
Total request limit for the window |
x-ratelimit-reset |
Unix timestamp when the rate limit resets |
Error Response
When rate limits are exceeded, a 429 Too Many Requests response is returned:
Module Structure
limiter: Contains the coreRateLimiterlogic,TokenBucketimplementation,RateLimiterConfig, and theRateLimitntex middleware.
Contributing
Contributions are welcome! Please feel free to open an issue or submit a pull request.
License
MIT All contributor.