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. 如图:
来源: http://www.bubuko.com/infodetail-3340864.html