ngx_http_limit_conn_module
ngx_http_limit_conn_module模块
- 示例配置
- 指令
- limit_conn
- limit_conn_log_level
- limit_conn_status
- limit_conn_zone
- limit_zone
该ngx_http_limit_conn_module
模块用于限制每个定义密钥的连接数量,特别是来自单个IP地址的连接数量。
并非所有的连接都被计数。只有在服务器处理了请求并且已经读取了整个请求头时才计算连接。
示例配置
http {
limit_conn_zone $binary_remote_addr zone=addr:10m;
...
server {
...
location /download/ {
limit_conn addr 1;
}
指令
句法: | limit_conn号; |
---|---|
默认: | — |
语境: | http,服务器,位置 |
设置给定键值的共享内存区域和最大允许连接数。超过此限制时,服务器将返回错误以回复请求。例如,指令
limit_conn_zone $binary_remote_addr zone=addr:10m;
server {
location /download/ {
limit_conn addr 1;
}
一次只允许每个IP地址一个连接。
在HTTP / 2和SPDY中,每个并发请求都被视为一个单独的连接。
可能有几个limit_conn
指令。例如,以下配置将限制每个客户端IP连接到服务器的数量,同时限制连接到虚拟服务器的总数:
limit_conn_zone $binary_remote_addr zone=perip:10m;
limit_conn_zone $server_name zone=perserver:10m;
server {
...
limit_conn perip 10;
limit_conn perserver 100;
}
当且仅当limit_conn
在当前级别上没有指令时,这些指令才从前一级继承。
句法: | limit_conn_log_level信息| 通知| 警告| 错误; |
---|---|
默认: | limit_conn_log_level错误; |
语境: | http,服务器,位置 |
当服务器限制连接数时,设置所需的日志记录级别。
句法: | limit_conn_status代码; |
---|---|
默认: | limit_conn_status 503; |
语境: | http,服务器,位置 |
设置状态码以响应拒绝的请求而返回。
句法: | limit_conn_zone key zone = name:size; |
---|---|
默认: | — |
语境: | HTTP |
为共享内存区域设置参数,该区域将保留各种键的状态。特别是,该状态包含当前的连接数。该key
可以包含文本,变量,他们的组合。不包括具有空键值的请求。
在版本1.7.6之前,一个
key
可能只包含一个变量。
用法示例:
limit_conn_zone $binary_remote_addr zone=addr:10m;
在这里,客户端IP地址作为关键。需要注意的是,而不是$remote_addr
,该$binary_remote_addr
变量在这里使用。该$remote_addr
变量的大小可以从7至15个字节而变化。存储状态在32位平台上占用32或64字节的内存,在64位平台上总是占用64字节。$binary_remote_addr
对于IPv4地址,变量的大小始终为4个字节,对于IPv6地址则为16个字节。存储状态在32位平台上始终占用32或64个字节,在64位平台上占用64个字节。一个兆字节的区域可以保持大约32000个32字节的状态或大约16000个64字节的状态。如果区域存储耗尽,服务器会将错误返回给所有其他请求。
句法: | limit_zone name $variable size ; |
---|---|
默认: | — |
语境: | HTTP |
该指令在版本1.1.8中已过时,并在版本1.7.6中被删除。应该使用改变语法的等效limit_conn_zone指令代替:
limit_conn_zone
$variable
zone
=name
:size
;