初探 Nginx 架构

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

 

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值