Home > Backend Development > PHP Tutorial > nginx limit the number of connections (ngx_http_limit_conn_module) module nginx concat module echo nginx module nginx upsync module

nginx limit the number of connections (ngx_http_limit_conn_module) module nginx concat module echo nginx module nginx upsync module

WBOY
Release: 2016-07-29 08:54:59
Original
1148 people have browsed it

ngx_http_limit_conn_module limits the number of concurrency for some servers with abnormal traffic, excessive load, or even large-traffic malicious attack access; this module can limit the number of connections for each key value based on the defined key, only those that are being used Connections that handle requests for which the header information has been fully read are counted.

This module provides two configuration parameters, limit_conn_zone and limit_conn. Limit_conn_zone can only be configured in the http{} section, while limit_conn can be configured in the http{}, server{}, and location{} sections.


1. limit_conn_zone

Syntax: limit_conn_zone $variable z
Configuration section: http

This directive describes the session state storage area. The current number of connections is saved in the key's state, and the value of the key can be any non-null value of a specific variable (null values ​​are not considered). $variable defines the key, z defines the area name, and its main function is the limit_conn that follows. size defines the shared memory space size of each key, such as:

nginx rtmp module,nginx upload module,lua nginx module,fastdfs nginx module,nginx sticky module,nginx add module,nginx concat module,echo nginx module,nginx upsync modul

Note:

The IP address of the client is used as the key. Note that the binary_remote_addr variable is used here, not the remote_addr variable.
The length of the remote_addr variable ranges from 7 bytes to 15 bytes, while the storage state occupies 32 bytes or 64 bytes in 32-bit platforms and 64 bytes in 64-bit platforms.
The length of the binary_remote_addr variable is fixed 4 bytes, and the storage state occupies 32 bytes or 64 bytes on 32-bit platforms, and 64 bytes on 64-bit platforms.
1M shared space can save 32,000 32-bit states and 16,000 64-bit states.
If the shared memory space is exhausted, the server will return a 503 (Service Temporarily Unavailable) error to all subsequent requests.


2. limit_conn

Syntax: limit_conn zone_name number
Configuration section: http, server, location

This directive specifies the maximum number of simultaneous connections for each given key value. When this number is exceeded, a 503 (Service) error is returned. For example (the same IP is only allowed to have 20 connections at the same time):

nginx rtmp module,nginx upload module,lua nginx module,fastdfs nginx module,nginx sticky module,nginx add module,nginx concat module,echo nginx module,nginx upsync modul


3. Configuration and usage examples

limit_conn_zone $binary_remote_addr z
Mainly used to define variables, zone names, and shared memory sizes

limit_conn showjoy_conn 20;
Configure the showjoy_conn defined earlier, and limit the number of concurrent connections for the same IP to 20

nginx rtmp module,nginx upload module,lua nginx module,fastdfs nginx module,nginx sticky module,nginx add module,nginx concat module,echo nginx module,nginx upsync modul


4. Precautions for use

Transactions have two sides. Although the ngx_http_limit_conn_module module can solve the current concurrency problems, it will introduce other problems. For example, if the front-end does LVS or reverse generation, and our back-end enables this module function, wouldn't there be a lot of 503 errors? In this case, you can enable the module on the front end, or set a whitelist.

Module address: https://yunpan.cn/cqSKP6BrJ2AeT Access password 4f50

').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i ').text(i)); }; $numbering.fadeIn(1700); }); });

The above introduces the nginx limit connection number (ngx_http_limit_conn_module) module, including module and nginx content. I hope it will be helpful to friends who are interested in PHP tutorials.

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template