• Nginx事件模块
  • accept_mutex
  • accept_mutex_delay
  • debug_connection
  • devpoll_changes
  • devpoll_events
  • kqueue_events
  • epoll_events
  • multi_accept
  • rtsig_signo
  • rtsig_overflow_events
  • rtsig_overflow_test
  • rtsig_overflow_threshold
  • use
  • worker_connections
  • References

    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