nginx的请求限制
一、http协议的连接与请求
总结:
HTTP请求是建立在一次TCP连接的基础之上。
一次TCP请求至少产生一次HTTP请求。
二、连接限制
limit_conn_module
配置语法:
Syntax: limit_conn_zone key zone=name:size;
Default: —
Context: http
Syntax: limit_conn zone number;
Default: —
Context: http, server, location
示例:
limit_conn conn_zone 1 :同一时刻只允许一个ip的请求过来。
三、请求频率限制
limit_req_module
Syntax: limit_req_zone key zone=name:size rate=rate [sync]; Default: — Context: http yntax: limit_req zone=name [burst=number] [nodelay | delay=number]; Default: — Context: http, server, location
示例:
说明:
$binary_remote_addr :客户端地址,不用$remote_addr,是因为 $binary_remote_addr更省空间。
zone=req_zone : 分配的存储空间名称。
reate=1r/s:对于同一个IP地址过来的所有的请求,限制为每秒只能发起1个请求。
配置limit_req_zone
用ab压力测试工具进行测试
//总共请求30次,并发为20 ab -n 30 -c 20 http://192.168.0.133/index.html
测试结果:
查看error.log,发现日志中有和多请求限制的错误。
第二种参数配置:
burst=3 表示客户的请求在超过指定的速率(本次配置为1r/s)后,遗留的3个请求释放到下一秒执行,会保证有3个请求在下一秒执行,起到一个访问限速的作用,即延迟响应。
nodelay 表示除了这3个请求外,其它的请求直接返回。
本文为袋鼠学习中的总结,如有转载请注明出处:https://www.cnblogs.com/chrdai/protected/p/11331504.html