一、PHP+nginx+php-fpm的運行機制和原理php
Nginx 是非阻塞IO & IO複用模型,經過操做系統提供的相似 epoll 的功能,能夠在一個線程裏處理多個客戶端的請求。(非阻塞,無需等待返回) Nginx 的進程就是線程,即每一個進程裏只有一個線程,但這一個線程能夠服務多個客戶端。 PHP-FPM 是阻塞的單線程模型,pm.max_children 指定的是最大的進程數量,pm.max_requests 指定的是每一個進程處理多少個請求後重啓(由於 PHP 偶爾會有內存泄漏,因此須要重啓). PHP-FPM 的每一個進程也只有一個線程,可是一個進程同時只能服務一個客戶端。(阻塞,需等待PHP返回結果)
大多數的 Linux 程序都傾向於使用進程而不是線程,由於 Linux 下相對來講建立進程的開銷比較小,而 Linux 的線程功能又不是很強大。 0
總結:nginx
一、nginx和php-fpm都是多進程,一個進程只有一個線程;面試
二、nginx一個線程是非阻塞/io多路複用/epoll模型,將請求分發後無需等待,僅監聽回調結果redis
三、php-fpm一個線程是阻塞模型,必須等待該客戶端請求php服務端返回數據,下一個nginx發過來的請求才能被受理網絡
四、PHP自己是單進程單線程的,它只是腳本語言。php-fpm
五、關於redis:redis是單進程單線程模型,它也是非阻塞、I/o多路複用、epoll模型。(面試請回答:單線程。)spa
其實嚴格來講,redis只是在處理網絡請求、數據處理及返回使用的是 單線程(I/O多路複用、epoll),它內部還有其餘線程 用來處理數據持久化rdb或aof。如圖:操作系統