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的高并发机制——异步非阻塞事件机制

同徽B2C电子商务软件系统
同徽B2C电子商务软件系统

开发语言:java,支持数据库:Mysql 5,系统架构:J2EE,操作系统:linux/Windows1. 引言 32. 系统的结构 32.1 系统概述 33. 功能模块设计说明 43.1 商品管理 43.1.1 添加商品功能模块 53.1.2 商品列表功能模块 83.1.3 商品关联功能模块 93.

下载

    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

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

705

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

233

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

117

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

22

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

61

2026.02.13

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

30

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

15

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

669

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

58

2026.02.12

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
进程与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号