0

0

nginx核心架构概述

php中文网

php中文网

发布时间:2016-08-08 09:20:15

|

1067人浏览过

|

来源于php中文网

原创

    毕业前,毕设完成后,我闲极无聊接触了一下socket编程,用c++的qt框架写了玩具一样的tcp和udp通信客户端。跟直系学长电话聊天时被建议深挖一下socket,尝试走走后端或者架构师路线。问该怎么深挖,答研究源码,要学习socket相关知识,研究服务器源码是最合适不过的了。至于选择哪个服务器,经过考量调查,发现比起比较沉重庞大的apache,nginx更加小巧,也非常优秀。于是在开始正式吃源码之前,我先开始了一番自我科普工作。

1、进程模型

    首先,默认的,与其他服务器一样,Unix下的nginx也以daemon(守护进程)的形式持续在后台运行。虽然nginx也可以以调试为目的关掉后台模式,使用前台模式,甚至可以通过配置取消master进程(后面会详细解释),使nginx以单进程的形式工作。但是这些与nginx引以为傲的架构关系不大,这里按下不表。尽管nginx也支持多线程方式,我们还是着重来了解下其默认的多进程方式。

    nginx在启动后会创建一个master进程(主进程)和若干个worker进程(从进程)。master进程主要负责管理worker进程,具体来说就是接收来自管理员的信号并转发给对应worker进程;监控worker进程的工作状态,在worker进程异常终止时重新创建并启动worker进程。而worker进程负责处理基本的网络事件。worker进程之间优先级对等、相互独立,公平竞争来自客户端的请求,每个请求只由一个worker进程处理。nginx进程模型示意图如图1所示。

 

1 nginx进程模型示意图

    worker进程的数量可以进行设置,一般设置与CPU核数一致,这一原则与nginx的事件处理模型有关。后面会继续介绍nginx的事件处理模型。

2、信号与请求

    nginx与外界互动无非通过两种接口界面:来自管理员的信号和来自客户端的请求。下面我们举例说明nginx是如何处理信号与请求的。

    管理员要控制nginx需要与master进程通信,向master进程发送指令信号即可。比如,nginx0.8版本之前使用kill -HUP [pid]命令来重启nginx。使用这个命令重启nginx将实现从容地重启过程,期间服务不中断。master进程在接到HUP指令后首先会重新加载配置文件,然后启动新的worker进程,向旧的worker进程发送停止信号。这时新的worker进程开始接收网络请求,旧的worker进程停止接收新的请求,等到处理完当前请求后,旧的worker进程就退出销毁了。在0.8版本以后,nginx引入了一系列命令行参数以方便管理服务器,比如./nginx -s reload./nginx -s stop,分别用来重启和停止nginx。执行操作命令时,我们实际上启动了一个新的nginx进程,这个进程在解析命令中的参数后,自行向master进程发送相应的信号,达成与之前手动发送信号相同的效果。

3、请求与事件

    服务器最常处理的就是80端口http协议的请求了, 以此为例说明一下nginx处理请求的过程。首先,每一个worker进程都是从master进程fork(分叉)而成的,master进程中先建立好需要监听的socket(套接字,即IP地址+端口号)和相应的listenfd(监听文件描述符或句柄)。我们知道socket通信中每个进程都要分配一个端口号,worker进程的socket分配工作就由master进程来完成。所有worker进程的listenfd在新的连接到来时变得可读,为保证只有一个worker进程处理连接,各worker进程在注册listenfd读事件前先要抢accept_mutex(接受连接互斥锁),一个worker进程抢注连接成功后,开始读取请求、解析请求、处理请求并反馈数据给客户端。

4、进程模型分析

    nginx使用但不仅仅使用多进程请求处理模型(PPC),每个worker进程一次只处理一个请求,使得请求间资源独立不需要上锁,进程间互不影响能并行处理请求。一个请求处理失败导致一个worker进程异常退出,不会使服务中断,而是由master进程立刻重新启动一个新的worker进程,降低了服务器面临的整体风险,使服务更加稳定。但是相比多线程模型(TPC),系统开销略大,效率略低,这需要借助别的手段来改进。

5、nginx的高并发机制——异步非阻塞事件机制

灵云AI开放平台
灵云AI开放平台

灵云AI开放平台

下载

    IIS的事件处理机制是多线程,每个请求独占一个工作线程。由于多线程比较占用内存,线程间的上下文切换(反复的对寄存器组进行保护现场和恢复现场的操作)带来的CPU开销也很大,多线程机制的服务器在面临数千并发量时,会给系统造成很大的压力,高并发性能并不算理想,当然如果硬件足够出色,能够提供足够的系统资源,系统压力也就不再是问题了。

    我们深入到系统层面讨论一下多进程与多线程,阻塞式机制与非阻塞式机制的区别。

    熟悉操作系统的同学应该了解,多线程的出现是为了在资源充足的情况下更充分的调度使用CPU,尤其对提高多核CPU的利用率十分有益。但是线程是系统任务的最小单位,而进程却是系统分配资源的最小单位,这就意味着多线程将面临一个很大的问题:当线程数增多,资源需求变大,这些线程的母进程可能无法立即一口气申请到足够所有线程使用的资源,而当系统手里没有足够的资源满足一个进程时,它会选择让整个进程都等着。这时即使系统资源足够一部分线程正常工作,母进程也无法申请到这些资源,导致所有线程一起等待。直白的说,使用多线程,进程内的线程间可以灵活的进行调度(虽然增加了线程死锁的风险和线程切换的开销),但是却无法保证母进程在逐渐庞大沉重时还能够在系统中得到合理的调度。由此可见,多线程确实可以提高CPU利用率,但是并不是解决服务器高并发请求问题的理想解决方案,且不说在高并发状态下CPU的高利用率也无法维持。以上是IIS的多线程同步阻塞式事件机制。

    nginx的多进程机制保证了每个请求独立申请系统资源,一旦满足条件,每一个请求都可以立即被处理,即异步非阻塞处理。但是创建进程需要的资源开销会比线程多一些,为了节约进程数,nginx使用了一些进程调度算法,使I/O事件处理不仅仅靠多进程机制,而是异步非阻塞的多进程机制。下面我们就来具体的引入nginx的异步非阻塞事件处理机制。

6、epoll

    Linux下,言高并发的高性能网络必epollnginx也正是使用了epoll模型作为网络事件的处理机制。我们先看看epoll是怎么来的。

    最早的调度方案是异步忙轮询方式,即持续的轮询I/O事件也就是遍历socket集合的访问状态,显然服务器空闲时这一方案造成了无谓的CPU开销。

    后来,selectpoll作为调度进程和提高CPU利用率的代理先后出现,字面上看,一个是选择,一个是投票,它们的本质相同,都是轮询socket集合并处理请求,与之前不同的地方在于,它们能够监视I/O事件,空闲时轮询线程将被阻塞,而一个或多个I/O事件到来时则被唤醒,摆脱了忙轮询,成为异步轮询方式。select/poll模型轮询的是整个FD(文件描述符)集合即socket集合,网络事件处理效率随着并发请求数线性降低,所以使用一个宏来限制最大并发连接数。同时,select/poll模型的内核空间与用户空间通信方式为内存复制,带来较高的开销。以上缺点催生了新模型的产生。

    epoll可以认为是event poll的简写,Linux内核为处理大批量文件描述符而作了改进的poll,是Linux下多路复用I/O接口select/poll的增强版本,它能显著提高程序在大量并发连接中只有少量活跃的情况下的系统CPU利用率。首先,epoll没有最大并发连接数的限制,上限是可以打开的最大文件数,这与硬件内存大小有关,1GB的机器上大约是10w左右;然后是epoll最显著的优点,它只对活跃socket进行操作,因为只有那些被内核I/O读写事件异步唤醒的socket才被放入ready队列,准备进入worker进程被处理,这在实际生产环境中节省了大量轮询开销,极大的提高了事件处理效率;最后,epoll使用共享内存(MMAP)的方式实现内核空间与用户空间的通信,省掉了内存复制的开销。额外的,nginx中使用epollET(边缘触发)工作模式即快速工作模式。ET模式下,只支持非阻塞socketFD就绪即由内核通过epoll发送通知,经过某些操作使FD不再是就绪状态时也会发送通知,但如果一直没有I/O操作导致FD变为未就绪状态将不再发送通知。总的来说,nginxLinux下是基于事件,利用epoll处理网络事件的。

版权声明:本文为博主原创文章,未经博主允许不得转载。

以上就介绍了nginx核心架构概述,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

49

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

89

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

276

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

59

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

99

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

105

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

230

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

619

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

173

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
进程与SOCKET
进程与SOCKET

共6课时 | 0.4万人学习

nginx浅谈
nginx浅谈

共15课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号