Nginx 工作原理

Nginx 工作原理

Nginx由内核和模块组成。

  Nginx本身做的工作实际很少,当它接到一个HTTP请求时,它仅仅是通过查找配置文件将此次请求映射到一个location block,而此location中所配置的各个指令则会启动不同的模块去完成工作,因此模块可以看做Nginx真正的劳动工作者。通常一个location中的指令会涉及一个handler模块和多个filter模块(当然,多个location可以复用同一个模块)。handler模块负责处理请求,完成响应内容的生成,而filter模块对响应内容进行处理。

用户根据自己的需要开发的模块都属于第三方模块。正是有了这么多模块的支撑,Nginx的功能才会如此强大。

Nginx的模块从结构上分为核心模块、基础模块和第三方模块:

  • 核心模块:HTTP模块、EVENT模块和MAIL模块
  • 基础模块:HTTP Access模块、HTTP FastCGI模块、HTTP Proxy模块和HTTP Rewrite模块,
  • 第三方模块:HTTP Upstream Request Hash模块、Notice模块和HTTP Access Key模块。

Nginx的模块从功能上分为如下三类:

  • Handlers(处理器模块)。此类模块直接处理请求,并进行输出内容和修改headers信息等操作。Handlers处理器模块一般只能有一个。
  • Filters (过滤器模块)。此类模块主要对其他处理器模块输出的内容进行修改操作,最后由Nginx输出。
  • Proxies (代理类模块)。此类模块是Nginx的HTTP Upstream之类的模块,这些模块主要与后端一些服务比如FastCGI等进行交互,实现服务代理和负载均衡等功能。

 

Nginx进程模型

Nginx默认采用多进程工作方式,Nginx启动后,会运行一个master进程和多个worker进程。其中master充当整个进程组与用户的交互接口,同时对进程进行监护,管理worker进程来实现重启服务、平滑升级、更换日志文件、配置文件实时生效等功能。worker用来处理基本的网络事件,worker之间是平等的,他们共同竞争来处理来自客户端的请求。

nginx的进程模型如图所示:

在创建master进程时,先建立需要监听的socket(listenfd),然后从master进程中fork()出多个worker进程,如此一来每个worker进程多可以监听用户请求的socket。一般来说,当一个连接进来后,所有在Worker都会收到通知,但是只有一个进程可以接受这个连接请求,其它的都失败,这是所谓的惊群现象。nginx提供了一个accept_mutex(互斥锁),有了这把锁之后,同一时刻,就只会有一个进程在accpet连接,这样就不会有惊群问题了。

先打开accept_mutex选项,只有获得了accept_mutex的进程才会去添加accept事件。nginx使用一个叫ngx_accept_disabled的变量来控制是否去竞争accept_mutex锁。ngx_accept_disabled = nginx单进程的所有连接总数 / 8 -空闲连接数量,当ngx_accept_disabled大于0时,不会去尝试获取accept_mutex锁,ngx_accept_disable越大,于是让出的机会就越多,这样其它进程获取锁的机会也就越大。不去accept,每个worker进程的连接数就控制下来了,其它进程的连接池就会得到利用,这样,nginx就控制了多进程间连接的平衡。

每个worker进程都有一个独立的连接池,连接池的大小是worker_connections。这里的连接池里面保存的其实不是真实的连接,它只是一个worker_connections大小的一个ngx_connection_t结构的数组。并且,nginx会通过一个链表free_connections来保存所有的空闲ngx_connection_t,每次获取一个连接时,就从空闲连接链表中获取一个,用完后,再放回空闲连接链表里面。一个nginx能建立的最大连接数,应该是worker_connections * worker_processes。当然,这里说的是最大连接数,对于HTTP请求本地资源来说,能够支持的最大并发数量是worker_connections * worker_processes,而如果是HTTP作为反向代理来说,最大并发数量应该是worker_connections * worker_processes/2。因为作为反向代理服务器,每个并发会建立与客户端的连接和与后端服务的连接,会占用两个连接。

Nginx处理HTTP请求流程

http请求是典型的请求-响应类型的的网络协议。http是文件协议,所以我们在分析请求行与请求头,以及输出响应行与响应头,往往是一行一行的进行处理。通常在一个连接建立好后,读取一行数据,分析出请求行中包含的method、uri、http_version信息。然后再一行一行处理请求头,并根据请求method与请求头的信息来决定是否有请求体以及请求体的长度,然后再去读取请求体。得到请求后,我们处理请求产生需要输出的数据,然后再生成响应行,响应头以及响应体。在将响应发送给客户端之后,一个完整的请求就处理完了。

处理流程图:

<think>嗯,用户想了解Nginx工作原理,需要详细解释。首先,我得回忆一下之前关于Nginx的知识点。根据用户提供的引用内容,Nginx主要基于事件驱动架构和异步非阻塞I/O模型,还有master-worker的多进程结构。用户可能想知道Nginx为什么能处理高并发,这涉及到它的进程模型和事件处理机制。需要分点解释,比如架构组成、事件驱动、进程间协作等。还要注意引用中的信息,比如引用4提到master进程和多个worker进程,引用5说明worker进程数与CPU绑定,这些都要整合进去。另外,用户可能需要了解配置示例,比如如何设置worker_processes和worker_connections。引用3和引用5提到worker进程数量与CPU核数相同,并绑定CPU,这部分需要详细说明配置方法。 还要考虑用户可能的深层需求,比如优化技巧或者实际应用场景。比如引用2提到的多进程IO模型,可以解释Nginx如何高效处理请求。同时,要确保回答结构清晰,分步骤讲解,让用户逐步理解。需要检查是否有遗漏的关键点,比如反向代理、负载均衡等功能是否属于工作原理的一部分,或者是否需要单独说明。根据引用3,Nginx不仅是HTTP服务器,还是反向代理和邮件代理,但用户的问题集中在工作原理,可能不需要深入扩展功能,但可以简要提及。最后,生成相关问题时要围绕Nginx的架构、优化、配置等,帮助用户进一步学习。例如,如何优化worker进程,或者事件驱动模型的优势。</think>### Nginx工作原理详解 Nginx的核心设计基于**多进程异步非阻塞模型**,其高性能源于以下关键机制: #### 1. 多进程架构 - **Master进程**:负责管理Worker进程,不直接处理请求[^4]。主要功能包括: - 读取并验证配置 - 启动/停止Worker进程 - 热重载配置(通过`nginx -s reload`触发)[^5] - **Worker进程**:实际处理请求的单元,数量通常与CPU核数相同[^5]。每个Worker独立运行事件循环,通过**CPU绑定**(如`worker_cpu_affinity`配置)减少缓存失效[^5]。 #### 2. 事件驱动模型 - **异步非阻塞I/O**:Worker进程使用`epoll`(Linux)或`kqueue`(BSD)等系统调用,监听多个连接的事件(如可读、可写),避免阻塞等待[^2]。 - **事件循环流程**: ``` 初始化 → 监听连接 → 事件触发 → 处理请求 → 返回结果 ``` 单Worker可同时处理数千连接,资源消耗极低[^4]。 #### 3. 请求处理优化 - **零拷贝技术**:通过`sendfile`系统调用直接在内核空间传输文件,减少用户态与内核态的数据拷贝[^3]。 - **内存池管理**:预分配内存块并复用,减少频繁内存分配的开销[^3]。 #### 4. 典型配置示例 ```nginx worker_processes auto; # Worker数量=CPU核数 events { worker_connections 1024; # 单Worker最大连接数 use epoll; # 指定事件模型 } ``` 此配置使Nginx在4核服务器上可支持约$4 \times 1024 = 4096$并发连接[^5]。 #### 5. 性能对比指标 | 服务器类型 | 并发处理能力 | 内存占用 | |------------------|--------------|----------| | Apache(Prefork)| 约500 | 高 | | Nginx | 约10,000 | 低 | 数据来源:Nginx官方基准测试[^1]
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值