限制并发连接数的模块为:http_limit_conn_module,地址:http://nginx.org/en/docs/http/ngx_http_limit_conn_module.html
限制并发请求数的模块为:http_limit_req_module,地址:http://nginx.org/en/docs/http/ngx_http_limit_req_module.html
这两个模块都是默认编译进Nginx中的。
示例配置:
http { limit_conn_zone $ binary_remote_addr区=addr: 10米; #美元limit_conn_zone server_name区=持之以恒:10米; 服务器{ limit_conn addr 1; limit_conn_log_level警告; limit_conn_status 503; } }
limit_conn_zone关键区=名字:大小;定义并发连接的配置
-
<李>可定义的模块为http模块。李>
<李>键关键字是根据什么变量来限制连接数,示例中有binary_remote_addr, server_name美元,根据实际业务需求。李>
<李>区定义配置名称和最大共享内存,若占用的内存超过最大共享内存,则服务器返回错误李>
示例中的<代码>美元binary_remote_addr> 代码是二进制的用户地址,用二进制来节省字节数,减少占用共享内存的大小。
limit_conn区数量;并发连接限制
-
<李>可定义模块为http服务器,位置模块李>
<李>区为指定使用哪个limit_conn_zone配置李>
<李>数量为限制连接数,示例配置中限制为1个连接。李>
limit_conn_log_level信息| | |警告通知错误;限制发生时的日志级别
-
<李>可定义模块为http服务器,位置模块李>
limit_conn_status代码;限制发生时的返回错误码,默认503
-
<李>可定义模块为http服务器,位置模块李>
limit_req_zone关键区=名字:大小率=率;定义限制并发请求的配置。
-
<李>若占用的内存超过最大共享内存,则服务器返回错误响应李>
<李>率定义的是请求速率,如10 r/s每秒传递10个请求,10 r/m每分钟传递10个请求李>
limit_req区=名字[破裂数量=][nodelay |延迟=号],
-
<李> 李>
<李>破裂=数量设置桶可存放的请求数,就是请求的缓冲区大小李>
<李> nodelay破裂桶的请求不再缓冲,直接传递,请速度求速率失效。李>
<李>延迟=第号一次接收请求时,可提前传递个数量请求。李>
limit_req_log_level信息| | |警告通知错误;限制发生时的日志级别
-
<李>可定义模块为http服务器,位置模块李>
limit_req_status 代码;限制发生时的错误码
-
<李>可定义模块为http服务器,位置模块李>
示例配置1
http { limit_req_zone binary_remote_addr带美元=1:10米率=1 r/s; limit_req区=一个破裂=5; }
请求速率为每秒传递1个请求.burst桶大小可存放5个请求。超出限制的请求会返回错误。
示例配置2
http { limit_req_zone binary_remote_addr带美元=1:10米率=1 r/s; limit_req区==5 nodelay破裂; }
示例配置2是在示例配置1当中添加了<代码> nodelay 代码>选项。那么率请求速率则不管用了。会直接传递破裂桶中的所有请求。超出限制的请求会返回错误。
示例配置3
http { limit_req_zone binary_remote_addr带美元=1:10米率=1 r/s; limit_req区=一个破裂=5延迟=3; }
示例配置3是在示例配置1当中添加了<代码>延迟=3> 代码选项。表示前3个请求会立即传递,然后其他请求会按请求速率传递。超出限制的请求会返回错误。
到此这篇关于nginx限制并发连接请求数的方法的文章就介绍到这了,更多相关nginx限制并发连接请求数内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!