Nginx事件模块

accept_mutex

Syntax:*accept_mutex [ on | off ]*

Default:*on*

nginx 使用连接互斥锁进行顺序的accept()系统调用.

accept_mutex_delay

Syntax:*accept_mutex_delay Nms;*

Default:*500ms*

如果一个进程没有互斥锁,它将延迟至少多长时间。默认情况下,延迟是500ms 。

debug_connection

Syntax:*debug_connection [ip | CIDR]*

Default:*none*

Since 0.3.54 this option support CIDR address format

This option gives you the ability to write debug log only for the clients of this IP/NET.

Several different directives are possible.

Example:

  1. error_log /var/log/nginx/errors;
  2. events {
  3. debug_connection 192.168.1.1;
  4. }

devpoll_changes

devpoll_events

kqueue_events

epoll_events

Syntax:*devpoll_changes*

Default:

These directives specify how many events may be passed to/from kernel, using appropriate method.

The default devpoll values are 32, the rest are 512.

multi_accept

Syntax:*multi_accept [ on | off ]*

Default:*off*

multi_accept tries to accept() as many connections as possible after nginx gets notification about a new connection.

rtsig_signo

Syntax:*rtsig_signo*

Default:

nginx uses two signals when the rtsig method is used. The directive specified the first signal number. The second is plus 1.

By default rtsig_signo is SIGRTMIN+10 (40).

rtsig_overflow_events

rtsig_overflow_test

rtsig_overflow_threshold

Syntax:*rtsigoverflow**

Default:

These directives specifies how to handle rtsig queue overflows. When overflow occurred nginx flushes rtsig queue, then it handles events switching between poll() and rtsig. poll() handles consecutively all unhandled events, while rtsig periodicaly drains queue to prevent a new overflow. When overflow is handled completely, nginx switches to rtsig method again.

The rtsig_overflow_events specifies the number of events to be passed via poll(). The default is 16.

The rtsig_overflow_test specifies after which number of events handled by poll() nginx will drains rtsig queue. The default is 32.

The rtsig_overflow_threshold works in Linux 2.4.x only. Before to drain rtsig queue nginx looks in a kernel how the queue is filled up

The default is 1/10. "rtsig_overflow_threshold 3" means 1/3.

use

Syntax:*use [ kqueue | rtsig | epoll | /dev/poll | select | poll | eventport ]*

Default:

如果在./configure的时候指定了不止一种事件模型,那么可以设置其中一个,以便告诉nginx使用哪种事件模型。默认情况下nginx会在./configure时找出最适合系统的事件模型。

你可以在 这里 查看可用的事件模型以及如何在./configure时激活

worker_connections

Syntax:*worker_connections number*

Default:

通过worker_connections和worker_proceses可以计算出maxclients:

  1. max_clients = worker_processes * worker_connections

作为反向代理,max_clients为:

  1. max_clients = worker_processes * worker_connections/4

Since a browser opens 2 connections by default to a server and nginx uses the fds (file descriptors) from the same pool to connect to the upstream backend

References

原文: https://wizardforcel.gitbooks.io/nginx-doc/content/Text/2.2_events.html