初探 Nginx 架构

Nginx 在启动后,会有一个 master 进程和多个 worker 进程。master 进程主要用来管理 worker 进程,而基本的网络事件,则是放在 worker 进程中来处理。多个 worker 进程之间是独立的。Nginx 的进程模型,可以由下图来表示

 

初探 Nginx 架构
Nginx进程模型

 

下面描述一个简单的nginx重启的过程,来说明master和worker的基本关系

          ./nginx -s reload命令重启,master 进程接到信号后,会启动新的 worker 进程,并向所有老的 worker 进程发送信号。新worker 接收新的请求,而老的 worker 不再接收新的请求,并且在当前进程中的所有未处理完的请求处理完成后退出。

 

master和worker的任务执行关系

          这里可以将master进程想象成一个任务公布栏,每次有请求进来都会发布在master上,并通知所有的worker进程来抢这个任务,ngixn通过accept_mutex 进程管理worker进程取任务的速度,accept_mutex 会使比较空闲的worker跑得更快,会抢先拿到这个事件,然后建立连接、读取请求、解析、处理、给客户端响应,最后断开连接。

高并发的实现:

          基本原理是,用异步非阻塞(点击查看js异步,概念都是一样的)代替多线程(点击查看进程与线程的关系处理并发,可以减小内存开销,并充分利用cpu性能。

初探 Nginx 架构

 

主要借鉴:https://www.w3cschool.cn/nginx/ycn81k97.html

参考资料:http://tengine.taobao.org/book/chapter_12.html