0


nginx并发数限制 limit_conn

当服务器面临高并发访问时,若连接数没有得到恰当的控制,则服务器的性能将受到影响,甚至可能导致崩溃。Nginx 的 limit_conn 指令是一个非常重要的服务器安全设置,可用于限制和控制并发连接数量。

基本语法

limit_conn 指令的基本语法为:

limit_conn connlimit;

其中,connlimit 为最大并发连接数。一旦某时刻,连接数超过该值,Nginx 将返回 503 错误页面并关闭新连接的接入。使用 error_page 指令可对此页面进行自定义配置。

除了主要指令之外,limit_conn 可用的其他一些参数包括:

  • limit_conn_zone:将连接数限制在完整区域范围内,而不是在整个 Nginx 实例中限制连接数。
  • limit_conn_log_level:日志等级,用于记录请求详细信息。
  • limit_conn_status:在错误页面中返回状态码。

实验

下面是一个实例:

http {
    limit_conn_zone $binary_remote_addrzone=connzone:10m;
    server {
        location / {
            limit_rate 20;
            limit_conn connzone 1;
            index index.html;}}}

在该示例中,limit_conn_zone 为 IP 地址创建一个限制连接数的区(或组)。所创建的区名为 connzone,大小为 10MB,表示在该区中针对单个 IP 地址进行最大连接数限制为 1,limit_rate表示对用户访问限速为20字节。达到最大连接数限制时,Nginx 将自动拒绝新的请求并返回 503 错误页面。

nginx配置

在这里插入图片描述

使用jmeter测试

安装Jmeter

参考官网:https://jmeter.apache.org/download_jmeter.cgi

新建 Thread Group

在这里插入图片描述
如下图设置并发量为10,循环次数为4
在这里插入图片描述

新建 HTTP Request

在这里插入图片描述
这里填写你的nginx的ip和端口
在这里插入图片描述

添加 View Results in Table在这里插入图片描述

执行并发请求

如下图,可以看到有4次成功,并且都是在线程组的第一个成功,说明限制并发数1生效
在这里插入图片描述

总结

通过使用 limit_conn 指令,您可以控制并发连接的数量,大大提高服务器的安全性和稳定性。在处理高并发请求时,限制连接数是保证服务器正常运行的关键设置之一。

标签: nginx 服务器 运维

本文转载自: https://blog.csdn.net/huangjuan0229/article/details/130057818
版权归原作者 JudithHuang 所有, 如有侵权,请联系我们删除。

“nginx并发数限制 limit_conn”的评论:

还没有评论