0

最近在学习高并发,关于php的运行机制,我有点疑惑。
我自己是这样认为的: 比如 php接受一个请求,运行5秒钟(夸张点说),那么10:00 的时候如果同时有5个请求连接php , 那么是不是 其中一个请求首先被执行,然后其他4个处于阻塞(等待)中 ? 10:05 第一个请求执行完毕,然后执行第二个......
10:00 第一个开始执行
10:05 第二个开始执行
10:10 第三个开始执行



这这样的吗 ? 还是说 php 像 比如 浏览器这样,可以同时开多个窗口同时处理呢 ?

pascal 144
3月14日提问

查看全部 2 个回答

1

PHP-FPM下,一个进程同一时刻只能处理一个请求,请求结束后不会关闭进程,但进程会释放资源。
你可以这样理解,每来一个请求,PHP-FPM的工作进程会调用内置的PHP解释器执行脚本处理请求,完成后释放资源接着处理下一个请求,但工作进程本身是支持后台常驻的。
另外,如果PHP跑在Swoole下,则PHP逻辑是常驻内存的,即PHP里的全局资源,包括定义的全局变量、函数、类,则都是常驻内存的。

推荐答案

2

PHP是属于多进程模型

在PHP开启进程的时候,就会启动配置的marster进程及相应的配置数的worker进程,如:

root      1051  0.0  0.2 274644  5588 ?        Ss   2月19   2:57 php-fpm: master process (/usr/local/php/etc/php-fpm.conf)
www       1063  0.0  0.8 282620 15744 ?        S    2月19   0:42 php-fpm: pool www
www       1065  0.0  0.7 281080 13724 ?        S    2月19   0:41 php-fpm: pool www
www       1071  0.0  0.7 280824 14092 ?        S    2月19   0:40 php-fpm: pool www
www       1072  0.0  0.6 279536 12836 ?        S    2月19   0:44 php-fpm: pool www
www       1076  0.0  0.7 281080 14328 ?        S    2月19   0:41 php-fpm: pool www
www       1077  0.0  0.7 280828 14124 ?        S    2月19   0:42 php-fpm: pool www
www       1083  0.0  0.7 281084 14440 ?        S    2月19   0:41 php-fpm: pool www

php-fpm master进程负责创建和管理woker进程,同时负责监听listen连接,master进程是多路复用的;woker进程负责accept请求连接,同时处理请求,一个woker进程可以处理多个请求(复用,不需要每次都fork一个woker进程),但一个woker进程一次只能处理一个请求。
至于worker进程的配置,你可以再详细去了解一下。

推广链接