Nginx系列p4:进程结构

Nginx 有两种进程结构:单进程结构,多进程结构。本篇文章我们主要说多进程结构。

:那为什么 Nginx 采用多进程结构,而不是多线程结构呢?

:这是因为 Nginx 最核心的目的就是要保证高可用性和高可靠性,当 Nginx 采用了多线程结构的时候,因为多个线程是共享同一个地址空间的,所以当一个第三方模块引发了一个地址空间导致的段错误时,在导致地址越界时,会导致整个 Nginx 进程挂掉。

单进程结构:不适用于生产环境,只用于调试。因为在生产环境中,nginx 要求要足够的健壮,而且要利用 CPU 多核的一个特性。

 

多进程结构:

 

1:master 进程:第三方模块一般不会在 master 进程中加入自己的功能代码的。目的是管理 worker 进程,比如:监控每个 worker 进程是不是在正确的工作,需不需要做重新载入文件,需不需要做热部署,等等。

2,worker 进程:主要用来处理请求,一般设置为当前计算机的核数,是每一个 worker 进程绑定到一个 cpu 核上,这样可以更好的使用 cpu 核上的 cpu 缓存,来减少 cpu 缓存失效的命中率。

3,Cache Manager:做缓存的管理。

4,Cache Loader: 做缓存的载入。

 

注:上述进程间的通信都是通过共享内存来实现的。

 

posted on   爱笑的张飞  阅读(176)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· AI Agent开发,如何调用三方的API Function,是通过提示词来发起调用的吗
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

导航

统计

点击右上角即可分享
微信分享提示