Nginx http_limit_req_module服务器请求限流

本文介绍了Nginx的ngx_http_limit_req_module模块,用于限制服务器资源请求,防止恶意压测和CC攻击。该模块基于漏桶算法,提供流量整形和流量监管。详细阐述了配置示例,包括限制同一IP的访问频次、设置突发请求数和是否延迟处理。还讨论了在有CDN时如何获取真实IP进行限流,并给出了针对特定UA和网络爬虫限流的配置方法。
摘要由CSDN通过智能技术生成

nginx 可以使用ngx_http_limit_req对服务器资源请求进行限制,这对使用ab等工具恶意压测服务器和cc(challenge Collapsar)会有一定的防范作用。防止用户恶意攻击刷爆服务器。

ngx_http_limit_req_module模块是nginx默认安装的,所以直接配置即可。


该模块使用漏斗算法(Leaky Bucket),该算法有两种处理方式Traffic Shaping和Traffic Policing

在桶满水之后,常见的两种处理方式为:
1.暂时拦截住上方水的向下流动,等待桶中的一部分水漏走后,再放行上方水。
2.溢出的上方水直接抛弃。

将水看作网络通信中数据包的抽象,则方式1起到的效果称为Traffic Shaping,方式2起到的效果称为Traffic Policing
由此可见,Traffic Shaping的核心理念是"等待",Traffic Policing的核心理念是"丢弃"。它们是两种常见的流速控制方法

 

nginx中该模块的使用配置示例

limit_req_zone $binary_remote_addr zone=one:10m rate=
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值