Linux/Unix平台上搭建Nginx+Mongrel Cluster实现Rails高负载应用

wangyongwyk 2011-09-04

本文讲述如何在Linux/Unix平台上面搭建Nginx+Mongrel Cluster实现Rails高负载的应用。

安装PCRE库

Ruby代码 
  1. $ ftp ftp.csx.cam.ac.uk  
  2. username: anonymous  
  3. > cd pub/software/programming/pcre/  
  4. > get pcre-7.4.tar.bz2  
  5.   
  6. > quit  
  7. $ tar -jxvf pcre-7.4.tar.bz2  
  8. $ cd pcre-7.4  
  9. $ ./configure  
  10. $ make  



不需要安装它,只是编译nginx时需要用到而已。

安装nginx

Ruby代码  Linux/Unix平台上搭建Nginx+Mongrel Cluster实现Rails高负载应用
  1. $ wget http://sysoev.ru/nginx/nginx-0.5.32.tar.gz  
  2.   
  3. $ tar -zxvf nginx-0.5.32.tar.gz  
  4. $ cd nginx-0.5.32  
  5. $ ./configure –with-pcre=../pcre-7.4  
  6. $ make  
  7. $ sudo make install  



配置nginx
修改/usr/local/nginx/conf/nginx.conf:

Ruby代码  
  1. user  someuser;  
  2. worker_processes  1;  
  3.   
  4. error_log logs/error.log  notice;  
  5.   
  6. pid logs/nginx.pid;  
  7.   
  8. events {  
  9.     worker_connections  1024;  
  10. }  
  11.   
  12. http {  
  13.     include       conf/mime.types;  
  14.     default_type  application/octet-stream;  
  15.   
  16.     access_log  logs/access.log;  
  17.   
  18.     sendfile        on;  
  19.     tcp_nopush     on;  
  20.   
  21.     keepalive_timeout  65;  
  22.     tcp_nodelay        on;  
  23.   
  24.     gzip  on;  
  25.     gzip_min_length  1100;  
  26.     gzip_buffers     4 8k;  
  27.     gzip_types       text/plain;  
  28.   
  29.     upstream mongrel {  
  30.         server 127.0.0.1:8100;  
  31.         server 127.0.0.1:8101;  
  32.         server 127.0.0.1:8102;  
  33.         server 127.0.0.1:8103;  
  34.     }  
  35.   
  36.     server {  
  37.         listen       80;  
  38.         server_name  your.server.com;  
  39.         location / {  
  40.             proxy_pass http://mongrel;  
  41.         }  
  42.   
  43.         root /home/your/app/path;  
  44.   
  45.         access_log  off;  
  46.         rewrite_log on;  
  47.   
  48.         location ~ ^/$ {  
  49.             if (-f /index.html){  
  50.                 rewrite (.*) /index.html last;  
  51.             }  
  52.             proxy_pass  http://mongrel;  
  53.             proxy_set_header   Host             $host;  
  54.         }  
  55.   
  56.         location / {  
  57.             if (!-f $request_filename.html) {  
  58.                 proxy_pass  http://mongrel;  
  59.             }  
  60.             rewrite (.*) $1.html last;  
  61.         }  
  62.   
  63.         location ~ .html {  
  64.             root /home/your/app/path;  
  65.         }  
  66.   
  67.         location ~* ^.+.(jpg|jpeg|gif|png|ico|css|zip|tgz|gz|rar|bz2|doc|xls|  
  68.                                  exe|pdf|ppt|txt|tar|mid|midi|wav|bmp|rtf|js|mov)$ {  
  69.             root /home/your/app/path;  
  70.         }  
  71.         location / {  
  72.             proxy_pass  http://mongrel;  
  73.             proxy_redirect     off;  
  74.             proxy_set_header   Host             $host;  
  75.             proxy_set_header   X-Real-IP        $remote_addr;  
  76.             proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;  
  77.         }  
  78.     }  
  79. }  

启动 nginx
$ sudo /usr/local/nginx/sbin/nginx
配置启动 mongrel cluster

Ruby代码 

  1. $ cd /home/your/app/path  
  2. $ sudo mongrel_rails cluster::configure -e production \  
  3. -p 8100 -N 4 -c /home/your/app/path -a 127.0.0.1 \  
  4. –user mongrel –group mongrel  
  5. $ sudo mongrel_rails cluster::start  



配置 HTTP 认证
添加以下行到 nginx.conf:

Ruby代码 
  1. location  /  {  
  2.     auth_basic            "Restricted";  
  3.     auth_basic_user_file  conf/htpasswd;  
  4. }  



要生成htpasswd文件, 使用Apache附带的htpasswd命令:

$ sudo htpasswd -bc conf/htpasswd user pass

关于htpasswd命令的使用,可使用’htpasswd -h’察看帮助。
清理工作

$ rm -rf pcre-7.4
$ rm -rf nginx-0.5.32

更新:如果遇到redirect_to��定向问题,请检查你的nginx版本,老版本使用$http_host变量,因此应该对proxy_set_header做相应修改:

    proxy_set_header   Host             $host;

相关推荐

AllenYoung / 0评论 2014-07-04
jizhename / 0评论 2013-09-03