在 Web 服务中,限流是保护系统免受恶意攻击和过载的重要手段。Nginx 的 limit_req_zone
模块提供了灵活的限流机制,其中 burst
参数允许缓存处理一定程度的突发请求,从而平滑流量。然而,当 burst
队列设置得较大时,请求排队时间变长,导致用户响应时间(RT)增加,影响用户体验。为了解决这个问题,Nginx 引入了 nodelay
参数,它允许请求在排队时立即被处理。本文将详细介绍 burst
和 nodelay
参数的作用,并通过实际测试展示其效果。
配置基础
首先,我们回顾一下基本的限流配置,并引入 burst
参数:
http {
limit_req_zone $binary_remote_addr zone=mylimit:10m rate=2r/s;
}
server {
listen 80;
server_name example.com;
location / {
limit_req zone=mylimit burst=4;
}
}
在这个配置中,每个 IP 的请求速率被限制为每秒 2 次,同时允许最多 4 个突发请求进入队列缓存处理。如果突发请求超过 4 个,多余的请求将被拒绝或延迟处理。
引入 nodelay
参数
为了优化请求排队时间,我们可以在 location
块中使用 nodelay
参数。nodelay
参数与 burst
一起使用时,允许请求在进入 burst
队列后立即被后台 worker 处理,而不是等待前面的请求处理完。以下是修改后的