码迷,mamicode.com
首页 > Web开发 > 详细

【PHP+nginx+php-fpm】探讨它们的运行机制和原理

时间:2019-12-20 12:14:51      阅读:112      评论:0      收藏:0      [点我收藏+]

标签:epoll   创建   处理   多少   运行机制   php-fpm   结果   io复用   class   

1、PHP+nginx+php-fpm的运行机制和原理

Nginx 是非阻塞IO & IO复用模型,通过操作系统提供的类似 epoll 的功能,可以在一个线程里处理多个客户端的请求。(非阻塞,无需等待返回)
Nginx 的进程就是线程,即每个进程里只有一个线程,但这一个线程可以服务多个客户端。

PHP-FPM 是阻塞的单线程模型,pm.max_children 指定的是最大的进程数量,pm.max_requests 指定的是每个进程处理多少个请求后重启(因为 PHP 偶尔会有内存泄漏,所以需要重启).
PHP-FPM 的每个进程也只有一个线程,但是一个进程同时只能服务一个客户端。(阻塞,需等待PHP返回结果)
大多数的 Linux 程序都倾向于使用进程而不是线程,因为 Linux 下相对来说创建进程的开销比较小,而 Linux 的线程功能又不是很强大。 0

 

总结:

1、nginx和php-fpm都是多进程,一个进程只有一个线程;

2、nginx一个线程是非阻塞/io多路复用/epoll模型,将请求分发后无需等待,仅监听回调结果

3、php-fpm一个线程是阻塞模型,必须等待该客户端请求php服务端返回数据,下一个nginx发过来的请求才能被受理

4、PHP本身是单进程单线程的,它只是脚本语言。

 

5、关于redis:redis是单进程单线程模型,它也是非阻塞、I/o多路复用、epoll模型。(面试请回答:单线程。)

                    其实严格来说,redis只是在处理网络请求、数据处理及返回使用的是 单线程(I/O多路复用、epoll),它内部还有其他线程 用来处理数据持久化rdb或aof。如图:

技术图片

 

【PHP+nginx+php-fpm】探讨它们的运行机制和原理

标签:epoll   创建   处理   多少   运行机制   php-fpm   结果   io复用   class   

原文地址:https://www.cnblogs.com/xuzhengzong/p/12072141.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!