Php-fpm相当于多线程吗?nginx fork出的worker和PHP-fpm有什么关系
Php-fpm相当于多线程吗?nginx fork出的worker和PHP-fpm有什么关系
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
Php-fpm相当于多线程吗?nginx fork出的worker和PHP-fpm有什么关系
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
接受
或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
发布评论
评论(1)
php-fpm 是多进程的 fast-cgi 管理服务
nginx 主进程是单线程的, master 进程会 fork 出多个 worker 进程,每个 worker 进程也同样是单线程模式,worker 进程采用的是 epoll 模型,异步非阻塞/事件驱动/IO多路复用,所以 nginx 比较适用于处理高并发请求的场景,就像现在的 nodejs,nodejs 是单进程且单线程模式,master 进程只有一个线程,负责请求调度和轮询回调事件的处理工作。
在 nginx + php-fpm 的架构模式下
nginx 的 worker 服务进程会把请求转发给 php-fpm 服务,它们是通过 unix socket 或 tcp socket 进行通信的,worker 把 request_1 发送给 php-fpm 后并不会同步阻塞等待 php-fpm 返回数据,而是将此次请求放入事件队列,接着去处理新的请求 request_2,同时会监测有没有回调事件触发了,这里的回调事件便是 request_1 的请求处理好了并已经返回了数据,worker 只需要把数据返回给客户端即可。
php-fpm 相当于一个进程池,里面维系着一定数量的php服务进程,等待 nginx 的 worker 发送任务,处理完成后返回给 nginx 的 worker。