ホームページ >バックエンド開発 >PHPチュートリアル >PHP Core-LifeCycle
PHP Core---LifeCycle
PHP CORE
PHP核心由两个单独的部分组成,底层部分就是 Zend Engine, ZE负责把人类可读的脚本解析成为机器可读的tokens, 然后在一个处理空间中执行这些tokens,ZE同时还要处理内存管理,变量作用域以及分发(dispatch)函数调用;
另外一层就是PHP核心(php core),负责连接 ?绑定的SAPI层,SAPI即 Server Application Programming Interface, 通常会参考主机环境,例如IIS ?CLI ?CGI等等,它也提供了一个统一的控制层,用于safe_mode 和 open_basedir的检查,像连接文件和网络I/O的streams层,有fopen() fread() 以及fwriter()方法。
Lifecycles
当某一个主机环境下的SAPI启动的时候,例如/usr/local/apache/bin/apachectl启动时, php开始会去初始化他核心的子系统(subsystems), 接下来, 在这个启动程序的末尾, php会去装载每一个扩展部分(Extension)的代码以及调用它们的模块初始程序(Module Initialization routing , MINIT), 这样就让每一个Extension有机会去初始化内部的变量,资源的分配,资源句柄的注册以及在ZE里注册他们的函数,这样当脚本调用这些函数中的某一个的时候,ZE就会知道要执行哪一段代码。
? ? 接下来,PHP就会等待SAPI层要请求执行的一个页面,在CGI或者CLI SAPI这些环境之,这个是立即发生的并且只执行一次;在Apache, IIS或其他成熟的web server的SAPI中,他只在远程用户请求的时候才会发生,或者是重复任意次数,这两种也有可能是并发的。
? ?不管请求是如何到达的, PHP都会去请求ZE设置一个让脚本运行的环境,然后调用每一个扩展的请求初始化函数(Request Initialization?(RINIT
) function),?RINIT 让每一个Extension有机会去创建特殊的环境变量 , 分配请求指定的资源以及执行一些其他的,比如审计的任务。举个例子,比如Session Extension, 在php.ini文件中如果session.auto_start这个参数被设置为了1(默认是0), 级说明允许自动启动session, 那么RINIT将会自动触发用户空间的session_start()函数以及预先设置$_SESSION变量。
? ?一旦请求被初始化了之后, ZE就会将php脚本翻译为tokens, 最后成为可执行的操作码(opcodes), 如何操作码中调用了一个extension的函数,那么ZE将会把参数传递给这个函数,并且临时交出控制权知道函数执行完毕。
? ?当一份脚本执行完毕之后, php将会调用每一个extension的请求停止函数(Request Shutdown(RSHUTDOWN
) function)去执行最后一次的清理操作,例如将session变量保存到磁盘。 ? 然后 ZE会执行一个清理进程,即我们熟知的垃圾收集(garbage collection), ?garbage collection 能有效的在前一次请求的每一个变量上执行一个unset()方法来释放变量。
? ?当完成这些之后, php会等待SAPI的下一次请求或者只是一个终止操作, 在CGI and CLI SAPIs里没有下一次请求,?SAPI会马上执行shutdown操作。在执行shutdown期间, ?php会循环每一个extension, 并且调用他们的?Module Shutdown?(MSHUTDOWN
) functions, 这个与前面的Module Initialization routing是对应的。在终止了所有的extension之后, php最后会 shut down 他自己的核心子系统。
? ?从上我们可以看出, ?在一次请求的过程中,ZE和PHP CORE各司其责, ?php core负责接收请求处理请求, 而ZE负责php脚本的执行。
?
?
?
?