nginx+php的配置

作了N多次php环境的搭建,网上的方法还真是多,但是实际操作起来总有一些大大小小的出入,很多错误经常让我纠结不已.久病成医,渐渐地我自己就总结出了一些经验。自我感觉良好。

这种方法并非以前所流行的apache 加 php_module 的方式运行,我是采用nginx 作为web服务器,以fastcgi的方式运行php。

linux下编译:

nginx我还是习惯选择8.54的版本,它的编译依赖以下几个软件包,解压这些源码包,在configure中设置好这些源码的路径,nginx在编译的时候会自己将他们编译进去的:

   pcre:  主要用于rewrite等模块

   zlib: 这个不用说了

   openssl: 如果你还知道https这个东西,那么你懂的~~~(当然你可以不需要这个功能)

   md5 /sha1:  这两者都是用于生成信息摘要的希哈算法,这俩个东西不是必须的,但是我发现如果不选择其中一个那么openssl是不会成功地编译进nginx的

下面是我自己写的一个安装脚本,有temp-path字样的编译选项所设置都是nginx在运行时产生的临时文件的路径,pid-path,lock-path也是临时文件路径,log-path是日志文件路径,我因为自己机子上一些权限的问题所以要设置一下.一般情况下其实这些是不必要的,nginx默认会统统把生成的这些文件放在自己的安装目录下.

tmp=/tmp/nginx

log=/home/jsckdao/log

pcre=~/Downloads/pcre-8.02

zlib=~/Downloads/zlib-1.2.5-src

openssl=~/Downloads/openssl-0.9.8q

md5=~/Downloads/md5-1.3.0

./configure --prefix=/usr/local/nginx \

--http-proxy-temp-path=${tmp}/nginx-proxy.tmp \

--http-fastcgi-temp-path=${tmp}/nginx-fcgi.tmp \

--http-uwsgi-temp-path=${tmp}/nginx-uwsgi.tmp \

--http-scgi-temp-path=${tmp}/nginx-scgi.tmp \

--http-client-body-temp-path=${tmp}/nginx-client.tmp \

--pid-path=${tmp}/nginx.pid \

--lock-path=${tmp}/nginx.lock \

--http-log-path=${log}/http.log \

--error-log-path=${log}/http-error.log \

--with-pcre=$pcre \ #pcre 源码包的路径

--with-zlib=$zlib \ #zlib 源码包的路径

--with-http_ssl_module \ #起用ssl支持

--with-openssl=$openssl #openssl 源码包路径

make

make install

php(5.2)的编译可以复杂点,也可以简单点,因为我们编译php时主要目的是编译它的脚本引擎和一些核心库,很多外围的东西不一定非要在编译php的时候加进去,可以在需要的时候将它们编译成扩展库再修改配置文件来加载它们。

我的编译代码如下:

./configure  --prefix=/usr/local/php  \

--with-mysql=/usr/local/mysql \#设置mysql的安装路径

--enable-fastcgi \ #开启fastcgi支持

--enable-debug #支持调试

make

make install

其实关于mysql的那一句都是可以不要的,只是我懒得再编译一次mysql扩展,所以就这样把它直接编译进php了,这样做的前提是你必须先安装mysql。

令外还有一些注意事项:编译php时必须确保系统中拥有libxml2与libxml2-dev这俩个软件包,因为php默认会将xml的功能编译进去,所以xml的支持是必不可少的。还有一个就是autoconf这条命令了,在编译扩展的时候,phpize会调用系统中的这个命令来生成扩展包的configure文件,没有它你就不能作扩展了,这一点也是要记住的,毕竟linux下的php不像windows版那样事先把所有的扩展都编译好了。

至于window下nginx,php的安装就没有什么难度了,下个zip包,解压就能用,只要稍微配置就可以了.

配置:

如果只是想让php能运行的话那么直接输入命令:

./php-cgi   -b   3344 

这样就开启了php的fastcgi进程了,-b参数是绑定该进程的侦听端口,随便找个没用的端口填就可以了,这里绑定的是3344.

然后在nginx的配置文件中加上这么几行:

location ~ \.php$ {

  root              /home/jsckdao/www;          #这是你网站的根目录

  fastcgi_pass  127.0.0.1:3344;            #这里指定了fastcgi进程侦听的端口,nginx就是通过这里与php交互的

  fastcgi_index   index.php;            

  fastcgi_param SCRIPT_FILENAME  $document_root/$fastcgi_script_name;            

  include           fastcgi_params;        

}

如果要改nginx的侦听端口的话找到"listen"这么一项,改就是了.运行nginx,在/home/jsckdao/www目录中写一个测试文件test.php:

<?php

phpinfo();

?>

访问http://localhost:8080/test.php,如果显示了php所以的配置信息,那么就基本没什么问题,已经可以用这个环境写些php代码了.

至于php的调试器我选择xdebug,不为什么,习惯所致。加载xdebug时,在配置文件中的写法根据系统的不同好像也有点不同。linux下是:zend_extension_debug=<path>,window中加载的dll有两种,一种文件名会带有ts的后缀,这种要这要样写:zend_extension_ts=<path>另外一种就这样:zend_extension=<path&gt;,path一定要写绝对路径。虽然ts为何意我也不是很清楚,但是这些设置是一定不可以搞错的。

设置好后重新运行php-cgi,然后重新访问test.php,如果有xdebug的那一块出现了,那么就成功了.

当然这是一个很简单的配置,只能让你运行php,要想真正做成你需要的开发环境,还需要你根据自己的需要修改php和nginx的配置文件,这些配置内容很多,我自己也在学习中,就不好多讲了.

另外有一点需要注意,php的配置文件在它的源码包中有两个:php.ini-dist和php.ini-recommended,分别是针对生成环境和开发环境的配置.你需要把其中一个改名为php.ini.重启后查看phpinfo()的页面,靠上的地方有一项"Loaded Configuration File",它的值如果就是你的php.ini的路径,那么就没问题了,如果不是话,就看看上面一项"Configuration File (php.ini) Path",你把你的php.ini文件移到这个目录下在重启就可以了.因为php默认会在这个路径下寻找php.ini的.当然你也可以在运行php-cgi的时候设置你的php.ini路径,比如这样:

php-cgi    -b    3344   -c   /home/jsckdao/php.ini

这样就是把/home/jsckdao/php.ini这个文件作为配置文件了. 



来自:http://www.cnblogs.com/jsckdao/archive/2011/05/05/2038265.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Nginx是一款高性能的Web服务器,并且也可以作为反向代理服务器和负载均衡器使用。它的特点是占用资源少、稳定性高、并发能力强,可以处理大量的并发连接请求。 WSGI(Web Server Gateway Interface)是一种Web服务器和Python应用程序之间的通信协议。它定义了应用程序和服务器之间的接口规范,使得不同的Python框架(如Django和Flask)可以与Web服务器(如Nginx)进行通信,实现Web应用程序的部署和运行。 PHP 7.0是一种流行的开源脚本语言,常用于Web开发。它具有丰富的功能和扩展库,使得开发人员可以快速构建动态的网站和应用程序。在Nginx中,可以通过FastCGI模块来支持PHP的解析和执行。 结合这三者,我们可以使用Nginx作为Web服务器,通过WSGI协议将请求传递给Python应用程序,同时支持PHP解析和执行。具体的配置步骤如下: 1. 安装Nginx配置虚拟主机:通过在Nginx配置文件中添加虚拟主机,将请求定向到正确的域名或IP地址。 2. 安装和配置Python应用程序:确保Python应用程序与WSGI兼容,并安装必要的模块。可以使用Gunicorn作为WSGI容器,它可以与Nginx配合使用。 3. 配置Nginx与Python应用程序的通信:通过在Nginx配置文件中添加代理规则,将请求传递给Python应用程序。可以使用与WSGI兼容的Gunicorn的地址。 4. 配置NginxPHP的通信:通过将PHP解析器与FastCGI模块结合使用,实现NginxPHP的支持。可以通过在Nginx配置文件中添加相应的规则来实现。 这样,我们就可以在同一台服务器上同时支持Python和PHP应用程序。Nginx作为Web服务器和反向代理服务器,通过WSGI协议将请求传递给Python应用程序,并利用FastCGI模块支持PHP解析和执行。整个配置的目的是为了实现高性能和稳定性,以及对多种Web开发技术的支持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值