概览
1.1 特性
- 开源免费:PHP社群有大量的开发者贡献代码
- 快捷:程序开发快、运行快,技术本身学习快,实用性强
- 效率高:PHP消耗相当少的系统资源,自动gc机制
- 类库资源:有大量可用类库供开发者使用
- 扩展性:允许用户使用C/C++扩展PHP
- 跨平台:可以在unix,windows,mac os等系统上面使用PHP
1.2 PHP的相关组成
- SAPI : PHP本身可以理解为一个库函数,提供语言的编译和执行服务,它有标准的输入输出,SAPI 是PHP的接入层,接收用户的请求,然后调用PHP内核提供的一些接口完成PHP脚本的执行。PHP中常用的 SAPI 有cli、php-fpm。cli是命令行下执行脚本的,是单进程的,处理模型比较简单,而php-fpm相对复杂,实现了网络处理模块,用于与Web服务器交互。
- Zend引擎 : Zend 是PHP语言最为重要的部分,是PHP最基础、最核心的部分,PHP代码从编译到执行都是由 Zend 完成,Zend 整体由编译器(负责将PHP代码编译成抽象语法树,然后进一步编译为可执行的opcodes)和执行器(负责编译器输出的opcodes,执行PHP脚本中编写的代码逻辑)两部分构成。
- 扩展
1.3 执行流程
php_module_startup():模块初始化阶段
php_request_startup():请求初始化阶段
php_execute_script():执行PHP脚本阶段
php_request_shutdown():请求结束阶段
php_module_shutdown():模块关闭阶段
1.4 FPM
- 概述
FPM(FastCGI Process Manager)是PHP FastCGI运行模式的一个进程管理器。
PHP没有实现http网络库,而是实现了FastCGI协议,然后与Web服务器配合实现了http的处理。Web服务器来处理http请求,然后将解析的结果再通过FastCGI协议转发给处理程序,处理程序处理完成后将结果返回给Web服务器,Web服务器再返回给用户。
PHP实现了FastCGI协议的解析,但并没有实现具体网络处理,一般的处理模型:多进程,多线程。多进程模型通常是主进程只负责管理子进程,基本的网络事件都由子进程处理,nginx,fpm就是这种模型;多线程通常由主线程监听、接收请求,然后交子线程处理,memcached就是这种模式。 - 基本实现
fpm的实现就是创建一个master进程,在master进程中创建并监听socket,然后fork出多个子进程,这些子进程各自accept请求。fpm的子进程只能同时响应一个请求,只有把这个请求处理完才会accept下一个请求。
nginx与fpm有很大的区别,nginx的子进程通过epoll管理子进程,如果一个请求数据还未发送完成则会处理下一个请求,即一个进程会连接多个处理请求,它是非阻塞的模型,只处理活跃的套接字。