1. 搭建环境:
(1) 本机虚拟机地址192.168.100.142。虚拟机中启动nginx容器,php-fpm容器,mysql容器,均监听默认的端口;
(2) nginx容器配置文件中通过proxy_pass将php请求转发到php-fpm监听的9000端口;
(3) 为实验项目配置域名my.test.com,项目目录设定为/{rootPath}/yii/frontend/web(这是一个yii-advanced项目),并配置rewrite将访问重定向到项目目录下的index.php;
(4) 配置本机hosts文件以便通过域名访问本地项目(192.168.100.142 my.test.com)。
2. 一次php请求过程图解:
3. 一个php页面的请求过程说明
(1) 在本机浏览器中输入网址:my.test.com,请求被发送到hosts文件指定的192.168.100.142:80,即我本机虚拟机的80端口;
(2) 监听192.168.100.142:80的nginx接收到此次请求,由于这是一次Http请求,所以nginx的核心模块会把它交给Http模块来选择合适的Handler模块。
(3) 经过请求初始化与请求解析,确定请求/{rootPath}/yii/frontend/web/index.php页面的内容。由于这是一个php的请求,nginx会把此次请求交由反向代理模块中的fast-cgi模块,因为nginx不能直接和php通信,他们之间要通过fast-cgi协议才能相互理解。而nginx的fast-cgi模块会遵循fast-cgi协议将请求相关信息发送给proxy_pass指定的fast-cgi上游服务,这里就是指php-fpm;
(4) 这个php-fpm(PHP FastCGI 进程管理器)是php这一端遵循fast-cgi协议与web server进行通信的服务,这样请求就到了php这一边。
(5) php-fpm master管理着多个php-fpm worker进程,一次请求到来时它们通过抢夺accept锁的方式获得这次请求的执行权。然后由这个php-fpm worker开始执行这一次请求。
(6) 经过一系列的初始化后,由zend引擎对被请求的index.php页面内容进行词法分析和语法分析,生成可以由zend引擎执行的opcode,然后按顺序执行这些opcode,
执行完毕后会进行一系列请求关闭的工作,然后将处理结果反馈给fast-cgi的下游web server;
(5) nginx的fast-cgi模块拿到处理结果后,将结果交由一系列Filter模块进行响应内容的过滤与封装,最终反馈到请求终端。
至此,一次php页面的请求告一段落。
原文https://www.cnblogs.com/ling-diary/p/9292595.html
首先说下:大部分学web开发的,都明白一个东西,就是用户通过http请求,请求到服务器,然后服务器将用户所需要的内容整理出来返回给用户。但是,当请求到达服务器之后,里面具体发生了什么呢?
对于常规的图片了,音频了,文件了。这些东西web服务器是直接返回给用户的。不需要做处理。可是当请求的是php文件的时候。web服务器就需要对文件进行处理。对于php来说就需要web服务器执行php文件,然后把最后的结果返回给用户。那么web服务器作为一个通俗上来说信息接收和发送的东西,怎么才能认识php的语法并且执行呢?下面来说一说!
首先想调用php程序,需要用到php的sapi。这东西是php的接口,干啥的接口,当然是调用php的接口了。
打个比方就好比,你拿着一堆php代码,去了php家里,人家有个小窗户,接收这些代码,然后把解释过的代码,从小窗户里给你拿出来,sapi就是这么一个小窗户。
那么在来说说apache,nginx等等是怎么执行php的呢?
上面说到了sapi的接口,apache,nginx等等都是通过这些接口执行php的。
常用接口:
php5_module:给apache用的接口。
CGI:给nginx用的(apache也能用,而且比上一个好)
ISAPI:iis用的
CLI:给dos窗口用的(执行脚本)
具体的配置方法,之后再说吧。
总结:其实执行php都是通过sapi接口调取的。
---------------------
原文:https://blog.csdn.net/xf552527/article/details/87268632