初探 Nginx 架构
Nginx 在启动后,会有一个 master 进程和多个 worker 进程。master 进程主要用来管理 worker 进程,而基本的网络事件,则是放在 worker 进程中来处理。多个 worker 进程之间是独立的。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性能。