请解释一下 Nginx 服务器上的 Master 和 Worker 进程分别是什么?
Master 进程通常不处理客户端请求,主要负责管理和分配资源,在 Worker 进程宕机时会自动启动新的 Worker 进程,保证 Nginx 服务器的稳定运行。在需要重新加载或修改配置文件时,Master 进程也会处理这些操作。
-
上一篇
请解释一下 Nginx 服务器上的 Master 和 Worker 进程分别是什么?
<p>主程序 Master process 启动后,通过一个 for 循环来 接收 和 处理外部信号;</p><p><br></p><p>主进程通过 fork() 函数产生 worker 子进程 ,每个子进程执行一个 for循环来实现Nginx服务器对事件的接收和处理 。</p><p><br></p><p>一般推荐 worker 进程数与CPU内核数一致,这样一来不存在大量的子进程生成和管理任务,避免了进程之间竞争CPU 资源和进程切换的开销。而且 Nginx 为了更好的利用 多核特性 ,提供了 CPU 亲缘性的绑定选项,我们可以将某一个进程绑定在某一个核上,这样就不会因为进程的切换带来 Cache 的失效。</p><p><br></p><p>对于每个请求,有且只有一个工作进程 对其处理。首先,每个 worker 进程都是从 master进程 fork 过来。在 master 进程里面,先建立好需要 listen 的 socket(listenfd) 之后,然后再 fork 出多个 worker 进程。</p><p><br></p><p>所有 worker 进程的 listenfd 会在新连接到来时变得可读 ,为保证只有一个进程处理该连接,所有 worker 进程在注册 listenfd 读事件前抢占 accept_mutex ,抢到互斥锁的那个进程注册 listenfd 读事件 ,在读事件里调用 accept 接受该连接。</p><p><br></p><p>当一个 worker 进程在 accept 这个连接之后,就开始读取请求、解析请求、处理请求,产生数据后,再返回给客户端 ,最后才断开连接。这样一个完整的请求就是这样的了。我们可以看到,一个请求,完全由 worker 进程来处理,而且只在一个 worker 进程中处理。</p><p><br></p><p>在 Nginx 服务器的运行过程中, 主进程和工作进程 需要进程交互。交互依赖于 Socket 实现的管道来实现。</p>
-
下一篇
请解释一下 Nginx 服务器上的 Master 和 Worker 进程分别是什么?
请解释一下 Nginx 服务器上的 Master 和 Worker 进程分别是什么?
相关文章
- 请列出与PHP相关的缓存机制及其优缺点。
- 如何在Golang中进行并发编程?
- 请给一个例子解释一下PHP中的闭包函数是什么?
- 请举例说明PHP中如何处理异常?
- PHP中常用的设计模式有哪些?
- 如何在Golang中实现单例模式?
- 请问PHP中如何实现多线程?
- PHP中如何处理文件上传和下载?
- 请解释什么是defer语句,以及它有什么作用?
- 请解释一下PHP中的MVC模式是如何工作的?
- 在PHP中,Magic Method都有哪些,并举例说明它们的作用?
- 请解释下PHP中会话(session)和Cookie(cookie)的作用。
- 请描述在Golang中使用MongoDB时的最佳实践。
- 请解释HTTP的基本概念,以及在Golang中如何使用HTTP?
- 请谈谈您对PHP的垃圾回收机制的了解及实践。
- 如何通过PHP来保护您的代码免受SQL注入攻击?
- PHP中如何进行单元测试以及如何在开发过程中保证代码质量?
- PHP7和PHP5的性能上有什么差别?
- 请提供至少三个通过PHP实现的网站性能优化技巧。
- 聊一下高并发和高性能的区别和联系?
微信收款码
支付宝收款码