php如何和linux进行通讯
FastCGI原理 Nginx+PHP-fpm实现原理 Nginx本身不会对PHP进行解析,终端对PHP页面的请求将会被Nginx交给FastCGI进程监听的IP地址及端口,由PHP-fpm作为动态解析服务器处理,最后将处理结果再返回给Nginx。其实,Nginx就是一个反向代理服务器。Nginx通过反向代理功能将动态请求转向后端PHP-fpm,从而实现对PHP的解析支持,这就是Nginx实现PHP动态解析的原理。 Nginx不支持对外部程序的直接调用或者解析,所有的外部程序(包括PHP)必须通过FastCGI接口来调用。FastCGI接口在Linux下是socket(这个socket可以是文件socket,也可以是ip socket)。为了调用CGI程序,还需要一个FastCGI的wrapper(wrapper可以理解为用于启动另一个程序的程序),这个wrapper绑定在某个固定socket上,如端口或者文件socket。当Nginx将CGI请求发送给这个socket的时候,通过FastCGI接口,wrapper接收到请求,然后派生出一个新的线程,这个线程调用解释器或者外部程序处理脚本并读取返回数据;接着,wrapper再将返回的数据通过FastCGI接口,沿着固定的socket传递给Nginx;最后,Nginx将返回的数据发送给客户端。 Nginx 简单配置 location ~ .PHP$ { root /home/admin/web/Nginx/html/; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.PHP; fastcgi_param SCRIPT_FILENAME /home/admin/web/Nginx/html/$fastcgi_script_name; include fastcgi_params; } 当Nginx接收到一个http请求时,通过配置文件找到对应的server。然后匹配server中的所有location,找到最匹配的。而在location中的命令会启动不同的模块去完成工作,比如rewrite模块、index模块。因此在Nginx中模块可以看作真正的劳动工作者。Nginx的模块是被编译到Nginx中的,属于静态方式。启动Nginx时,模块被自动加载。不像apache,把模块单独编译成so文件,在配置文件中指定是否加载。所以,单比模块加载方面,Nginx也比apache速度上有提升。 那Nginx是怎么调用PHP的呢?先看下面的Nginx中关于PHP的配置 something location ~ .PHP$ { root /webpath; fastcgi_pass 127.0.0.1:9000; … ... } 这个location指令把以PHP为文件后缀的请求,交给127.0.0.1:9000处理。我想你看到这个应该猜到了,这是一个C/S架构东西。 而这里的IP地址和端口(127.0.0.1:9000)就是fastcgi进程监听的IP地址和端口。fastcgi是一个可伸缩地、高速地在http server和动态脚本语言间通信的接口。多数流行的http server都支持fastcgi,包括apache、Nginx和lighttpd等。同时,fastcgi也被许多脚本语言支持,其中就有PHP。 那这个fastcgi的配置IP和端口从何而来呢?在PHP-fpm.conf中可以看到如下: something listen = 127.0.0.1:9000 #这个表示PHP的fastcgi进程监听的ip地址以及端口 pm.start_servers = 2 fastcgi进程管理器PHP-fpm自身初始化,启动主进程PHP-fpm和启动start_servers个fastcgi子进程。主进程PHP-fpm主要是管理fastcgi子进程,监听9000端口,fastcgi子进程等待请求。当客户端请求到达Nginx时,Nginx通过location指令,将所有以PHP为后缀的文件都交给 127.0.0.1:9000 来处理。PHP-fpm选择并连接到一个fastcgi子进程,并将环境变量和标准输入发送到fastcgi子进程。fastcgi子进程完成处理后将标准输出和错误信息返回。当fastcgi子进程关闭连接时,请求便告处理完成,等待下次处理。
(编辑:北几岛) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |