Java架构师—Nginx的进程模型

前言

       Nginx的进程模型;Nginx处理Web请求机制;同步与异步,阻塞与非阻塞。




一、Nginx的进程模型

1.1 master进程与woker进程

  • master进程:主进程
  • woker进程:工作进程
ps -ef|grep nginx

master进程与woker进程

1.2 master管理worker

  • master用于接收外界的信号/指令,将信号/指令传递给worker。
  • master可以监控worker,worker进程异常退出,master可以重新启动一个worker。

信号:

./nginx -s stop
./nginx -s quit
./nginx -s reload
./nginx -t

master管理worker

二、Nginx处理Web请求机制

       Nginx支持并发数几十万,甚至几百万。那么它究竟是怎么做到的呢?

2.1 Worker抢占机制

Worker抢占机制

2.2 传统服务器事件处理与Nginx事件处理比较

传统服务器事件处理
传统服务器事件处理
Nginx事件处理:异步非阻塞。
Nginx事件处理

三、同步与异步,阻塞与非阻塞

       阻塞与非阻塞、同步与异步,很多人可能会认为同步就是阻塞,异步就是非阻塞,非也非也。今天我们一起聊赖它们之间的区别:
这四个概念两两组合,会形成四个新的概念,如下:

3.1 同步阻塞

       客户端发送请求给服务端,此时服务端处理任务时间很久,则客户端则被服务端堵塞了,所以客户端会一直等待服务端的响应,此时客户端不能做其他任何事,服务端也不会接受其他客户端的请求。这种通信机制比较简单粗暴,但是效率不高。

3.2 同步非阻塞

       客户端发送请求给服务端,此时服务端处理任务时间很久,这个时候虽然客户端会一直等待响应,但是服务端可以处理其他的请求,过一会回来处理原先的。这种方式很高效,一个服务端可以处理很多请求,不会在因为任务没有处理完而堵着,所以这是非阻塞的。

3.3 异步阻塞

       客户端发送请求给服务端,此时服务端处理任务时间很久,但是客户端不会等待服务器响应,它可以做其他的任务,等服务器处理完毕后再把结果响应给客户端,客户端得到回调后再处理服务端的响应。这种方式可以避免客户端一直处于等待的状态,优化了用户体验,其实就是类似于网页里发起的ajax异步请求。

3.4 异步非阻塞

       客户端发送请求给服务端,此时服务端处理任务时间很久,这个时候的任务虽然处理时间会很久,但是客户端可以做其他的任务,因为他是异步的,可以在回调函数里处理响应;同时服务端是非阻塞的,所以服务端可以去处理其他的任务,如此,这个模式就显得非常的高效了。

3.5 BIO/NIO/AIO之间的概念与区别

       以上四点,除了第三点,其余的分别为BIO/NIO/AIO。
可以用生活实例来阐述:

  1. BIO: 我去上厕所,这个时候坑位都满了,我必须等待坑位释放了,我才能上吧?!此时我啥都不干,站在厕所里盯着,过了一会有人出来了,我就赶紧蹲上去。
  2. NIO: 我去上厕所,这个时候坑位都满了,没关系,哥不急,我出去抽根烟,过会回来看看有没有空位,如果有我就蹲,如果没有我出去接着抽烟或者玩会手机。
  3. 异步阻塞: 我去上厕所,这个时候坑位都满了,没事我等着,等有了新的空位,让他通知我就行,通知了我,我就蹲上去。
  4. AIO: 我去上厕所,这个时候坑位都满了,没事,我一点也不急,我去厕所外面抽根烟再玩玩手机,等有新的坑位释放了,会有人通知我的,通知我了,我就可以进去蹲了。
           从这个生活实例中能可以看得出来:
  • 同步:就是我需要自己每隔一段时间,以轮训的方式去看看有没有空的坑位;
  • 异步:则是有人拉完茅坑会通知你,通知你后你再回去蹲;
  • 阻塞:就是在等待的过程中,你不去做其他任何事情,干等着;
  • 非阻塞:就是你再等待的过程中可以去做其他的事,比如抽烟、喝酒、烫头、玩手机。
           小结: 异步的优势显而易见,大大优化用户体验, 非阻塞 使得系统资源开销远远小于 阻塞 模式,因为系统不需要创建新的进程(或线程),大大地节省了系统的资源,如此多出来的系统资源可以给其他的中间件去服务了。

总结

Nginx的进程模型;Nginx处理Web请求机制;同步与异步,阻塞与非阻塞。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值