PHP基于FastCGI模式与httpd通信
实验环境:
1.VMware虚拟机
2.linux子机3台
3.本地测试机
实验目的:
通过FastCGI模式让动态语言与静态分离开来,当HTTP服务器每次遇到动态程序时,可以将其直接交付给FastCGI进程来执行,然后将得到的结果返回给浏览器,这种方式可以让HTTP服务器专一地处理静态请求或者将动态脚本服务器的结果返回给客户端,这在很大程度上提高了整个应用系统的性能。
实验拓扑:
前两篇博客写到httpd的编译和mysql的编译安装,这里就不在编译了。
编译php
./configure --prefix=/usr/local/php --with-mysql=mysqlnd --with-pdomysql=mysqlnd --with-mysqli=mysqlnd --with-openssl --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-p ng-dir --with-zlib --with-libxml-dir=/usr --enable-xml --en able-sockets --enable-fpm --with-mcrypt=/usr/local/libmcrypt --with-config-file-path=/etc --with-config-file-sc an-dir=/etc/php.d --with-bz2
上一次编译安装php的时候是基于作为httpd的模块编译的,其中
--withapxs2=/usr/local/httpd/bin/apxs 这一句就是把php编译成httpd的模块的,这次php是台独立的服务器,所以这里编译的时候--enable-fpm启用fpm。
编译安装php遇到的问题:
1.提示bzip2让重新安装
只要你确定bzip2装过了,还提示这个错误,那就是你的bzip2-devel这个包没有安装,用光盘安
2.编译时需要用mcrypt的时候,编译有时会提示libmcrypt这个包找不到,让重新安装
下载libmcrypt这个包,编译安装./configure –prefix=/usr/local/libmcrypt,如果还提示找不到
libmcrypt的时候,就在编译php的时候,里面的参数—with-mcrypt指定路径,--with-
mcrypt=/usr/local/libmcrypt
为php提供配置文件:
# cp php.ini-production /etc/php.ini
配置php-fpm
为php-fpm提供SysV init脚本,并将其添加至服务列表:
# cp sapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm # chmod +x /etc/rc.d/init.d/php-fpm # chkconfig --add php-fpm # chkconfig php-fpm on
为php-fpm提供配置文件:
# cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf
编辑php-fpm的配置文件:
# vim /usr/local/php/etc/php-fpm.conf 配置fpm的相关选项为你所需要的值,并启用pid文件(如下最后一行): pm.max_children = 50 允许同时运行的最大并发数 pm.start_servers = 5 启动时启动多少个空闲进程 pm.min_spare_servers = 2 最小空闲进程数 pm.max_spare_servers = 8 最大空闲进程数 pid = /usr/local/php/var/run/php-fpm.pid
注意:这里面还有一个listen监听端口,端口默认是9000,但是前面的ip一定得是你php服务器的ip,千万不要是127.0.0.1,要不会出现以下错误
默认情况下,fpm监听在127.0.0.1的9000端口,也可以使用如下命令验正其是否已经监听在相应的套接字。这里要使用php服务器的ip:192.168.0.3
接下来就可以启动php-fpm了:
# service php-fpm start
配置httpd-2.4.9
启用httpd的相关模块
在Apache httpd 2.4以后已经专门有一个模块针对FastCGI的实现,此模块为mod_proxy_fcgi.so,它其实是作为mod_proxy.so模块的扩充,因此,这两个模块都要加载
查看两个模块
#ls /usr/local/httpd/modules
启用此模块:找到,并把前面的“#”去掉即可
#vim /etc/httpd/httpd.conf
如果想让httpd以fcgi协议与php通信,还需要httpd以反向代理的方式工作,配置虚拟主机支持使用fcgi
在相应的虚拟主机中添加类似如下两行。
ProxyRequests Off
ProxyPassMatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/PATH/TO/DOCUMENT_ROOT/$1
详解:
ProxyRequests Off:关闭正向代理
ProxyPassMatch:把以.php结尾的文件请求发送到php-fpm进程,php-fpm至少需要知道运行的目录和URI,所以这里直接在fcgi://127.0.0.1:9000(这里的ip地址指的是php所在服务器的ip)后指明了这两个参数,其它的参数的传递已经被mod_proxy_fcgi.so进行了封装,不需要手动指定。
例如:
编辑apache配置文件httpd.conf,让apache能识别php格式的页面,并支持php格式的主页
# vim /etc/httpd/httpd.conf
添加如下二行
AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps
定位至DirectoryIndex index.html ,修改为:
DirectoryIndex index.php index.html
测试:
在测试时,如果出现file not found这个错误页面的时候,那百分之八十你是把原理理解错了,用户在向httpd发起请求页面的时候,httpd看到如果是php动态页面的就交给php去处理,php处理完之后会传给httpd,那么就要注意了,根据原理的理解,httpd解析不了的文件交给php服务器,这句话的意思是,httpd服务器上是不会有php文件的,它只是看到自己解析不了的,就把这个文件发给php服务器了。所以说,如果要测试的话,这个php文件是要放在php服务器上的,至于路径那是必须要跟httpd服务器上定义的DocumentRoot的路径一样。
本文出自 “鱼儿” 博客,请务必保留此出处http://kyfish.blog.51cto.com/1570421/1544981
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。