`
jfi36jfi
  • 浏览: 17358 次
最近访客 更多访客>>
社区版块
存档分类
最新评论

linux下nginx+php的安装与配置

阅读更多

linux下nginx+php的安装与配置
2011年05月05日
  【简介】 Nginx 是一个很牛的高性能 Web 和 反向代理 服务器,它具有有很多非常优越的特性:
  在高连接并发的情况下,Nginx 是 Apache 服务器不错的替代品: Nginx 在美国是做虚拟主机生意的老板们经常选择的软件平台之一。 能够支持高达 50,000 个并发连接数的响应, 感谢 Nginx 为我们选择了 epoll and kqueue 作为开发模型.。
  Nginx 作为 负载均衡 服务器: Nginx 既可以在内部直接支持 Rails 和 PHP 程序对外进行服务,也可以支持作为 HTTP 代理服务器对外进行服务。 Nginx 采用 C 进行编写, 不论是系统资源开销还是 CPU 使用效率都比 Perlbal 要好很多。
  作为邮件代理服务器: Nginx 同时也是一个非常优秀的邮件代理服务器(最早开发这个产品的目的之一也是作为邮件代理服务器), Last.fm 描述了成功并且美妙的使用经验。
  Nginx 是一个安装非常简单,配置文件非常简洁(还能够支持perl语法), Bugs非常少的服务器: Nginx 启动特别容易,并且几乎可以做到 7*24 不间断运行,即使运行数个月也不需要重新启动。 你还能够不间断服务的情况下进行软件版本的升级。
  【Nginx 概述】
  HTTP 基础功能:
  处理静态文件,索引文件以及自动索引;
  反向代理加速(无缓存),简单的负载均衡和容错;
  FastCGI,简单的负载均衡和容错;
  模块化的结构。过滤器包括gzipping, byte ranges, chunked responses, 以及 SSI-filter 。在 SSI 过滤器中,到同一个 proxy 或者 FastCGI 的多个子请求并发处理;
  SSL 和 TLS SNI 支持;
  IMAP/POP3 代理服务功能:
  使用外部 HTTP 认证服务器重定向用户到 IMAP/POP3 后端;
  使用外部 HTTP 认证服务器认证用户后连接重定向到内部的 SMTP 后端;
  认证方法:
  POP3: POP3 USER/PASS, APOP, AUTH LOGIN PLAIN CRAM-MD5;
  IMAP: IMAP LOGIN;
  SMTP: AUTH LOGIN PLAIN CRAM-MD5;
  SSL 支持;
  在 IMAP 和 POP3 模式下的 STARTTLS 和 STLS 支持;
  支持的操作系统:
  FreeBSD 3.x, 4.x, 5.x, 6.x i386; FreeBSD 5.x, 6.x amd64;
  Linux 2.2, 2.4, 2.6 i386; Linux 2.6 amd64;
  Solaris 8 i386; Solaris 9 i386 and sun4u; Solaris 10 i386;
  MacOS X (10.4) PPC;
  结构与扩展:
  一个主进程和多个工作进程。工作进程是单线程的,且不需要特殊授权即可运行;
  kqueue (FreeBSD 4.1+), epoll (Linux 2.6+), rt signals (Linux 2.2.19+), /dev/poll (Solaris 7 11/99+), select, 以及 poll 支持;
  kqueue支持的不同功能包括 EV_CLEAR, EV_DISABLE (临时禁止事件), NOTE_LOWAT, EV_EOF, 有效数据的数目,错误代码;
  sendfile (FreeBSD 3.1+), sendfile (Linux 2.2+), sendfile64 (Linux 2.4.21+), 和 sendfilev (Solaris 8 7/01+) 支持;
  输入过滤 (FreeBSD 4.1+) 以及 TCP_DEFER_ACCEPT (Linux 2.4+) 支持;
  10,000 非活动的 HTTP keep-alive 连接仅需要 2.5M 内存。
  最小化的数据拷贝操作;
  其他HTTP功能:
  基于IP 和名称的虚拟主机服务;
  Memcached 的 GET 接口;
  支持 keep-alive 和管道连接;
  灵活简单的配置;
  重新配置和在线升级而无须中断客户的工作进程;
  可定制的访问日志,日志写入缓存,以及快捷的日志回卷;
  4xx-5xx 错误代码重定向;
  基于 PCRE 的 rewrite 重写模块;
  基于客户端 IP 地址和 HTTP 基本认证的访问控制;
  PUT, DELETE, 和 MKCOL 方法;
  支持 FLV (Flash 视频);
  带宽限制;
  实验特性:
  内嵌的 perl
  通过 aio_read()/aio_write() 的套接字工作的实验模块,仅在 FreeBSD 下。
  对线程的实验化支持,FreeBSD 4.x 的实现基于 rfork()
  Nginx 主要的英语站点是 http://sysoev.ru/en/
  英语文档草稿由 Aleksandar Lazic 完成 点击。
  安装之前需要3个支持:gzip,pcre,openssl
  【安装 Nginx】
  

  模块依赖性
  gzip 模块需要 zlib 库
  rewrite 模块需要 pcre 库
  ssl 功能需要 openssl 库
  预先编译好的安装包
  1 gzip支持,需要zlib http://www.zlib.net/ 下载最新版即可
  2 rewrite module requires pcre library http://www.pcre.org/ 下载最新版即可
  3 ssl 功能需要 openssl 库 http://www.openssl.org/ => http://www.openssl.org/source/ LASTEST版本即可
  我在安装过程中遇到了两个问题:
  1../configure: error: the HTTP cache module requires md5 functions
  from OpenSSL library.  You can either disable the module by using
  --without-http-cache option, or install the OpenSSL library into the system,
  or build the OpenSSL library statically from the source with nginx by using
  --with-http_ssl_module --with-openssl= options.
  2../configure: error: the HTTP rewrite module requires the PCRE library.
  第一个问题是需要安装openSSl,第二个需要安装pcre
  安装过程:
  1.安装编译openssl
  tar zxvf openssl.tar.gz
  cd openssl
  ./confbigure
  make
  make install
  2.安装编译gzip
  tar zxvf gzip.tar.gz
  cd gzip
  ./confbigure
  make
  make install
  3.安装编译pcre
  tar zxvf pcre.tar.gz
  cd pcre
  ./confbigure
  make
  make install
  4.安装nginx
  tar zxvf nginx.tar.gz
  cd nginx
  ./configure --with-pcre=../pcre --with-zlib=../zlib --with-http_ssl_module --with-openssl=../openssl
  make
  make install
  成功了。。。
  nginx目前还不能直接支持php,必须先借助于fastcgi来驱动php。现在fastcgi较好的办法有2种,一个是spawn-fcgi,另外一个就是php-fpm,一般来说可能php-fpm更强大一点.
  原文出处:http://home.phpchina.com/space.php?uid=14112&do=blog&id=184148
  在我安装nginx过程中,认为这篇文章帮助很大。
  最后执行成功的命令:
  root@ubuntu:~/nginx-0.9.1# ./configure --with-pcre=../pcre-8.01--with-zlib=../zlib-1.2.5 --with-http_ssl_module --with-openssl=../openssl-1.0.0c --add-module=../ngx_http_auth_pam_module-1.2 --with-http_sub_module --with-http_gzip_static_module --with-http_stub_status_module --with-http_flv_module --with-debug
  该命令是我增加了ngx_http_auth_pam_module 启动nginx:
  root@ubuntu:/usr/local/nginx/sbin# sudo ./nginx
  打开http://localhost,应该就可以成功了。
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics