欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

freeBSD下配置nginx+mongrel的rails部署环境 博客分类: ruby rails FreeBSDRailsnginxlighttpdMySQL 

程序员文章站 2024-03-14 19:06:59
...

      最近准备帮朋友开发一个小型的应用,考虑再三决定使用ROR,因为朋友提供的独立主机是FreeBSD6.1,只好研究在FreeBSD下怎么安装production级别的ROR部署环境。

      至于基本的软件怎么安装我这里就不多说了,网上的资源、信息很多,我这里提一下的是由于对FreeBSD不熟悉,使用ports安装的软件总是无法正确配置(还有就是可安装的软件版本太低),所以全部源码安装最新版本的软件。最终安装组合是:Nginx+Mongrel+Rails+MYSQL。

  小型应用,数据库就不说了MYSQL,重点就是WEB Server的前后端组合方案的的选择上了,查阅了大量网上资料,考虑了以下两种种备选方案:

      lighttpd + fcgi 或者 nginx +mongrel,

      首先想优先考虑速度性能,毕竟都在传说ROR的速度性能差,准备挑选lighttpd+FastCGI方案,但大佬说FastCGI会因各种原因爆炸在发射台上(想必是一个难配置、难维护的翻案),还有lighttpd和FastCGI的通信是一个专有的通信协议(tcp/unix socket?fcgi协议?),想一想java WEB应用的ajp就有点怕,我等小虾米碰到通信出了问题只能抓瞎。还有rail装在什么上面(用后面来表达更好?)运行呀?协议还要一个东西接受转发给rails呀,估计配置肯定麻烦,我理解的ROR本质就是简单,不简单的肯定走不远。所以目前速度最优的方案放弃。

     下面就选择通信性能较差的,但稳定,并且配置简便的使用proxy http通行的 nginx+Mongrel架构。备选方案中除了lighttpd+fcgi 就是nginx +mongrel主要是看了《Xen and the Art of Rails Deployment》中的:The year of the dog这句话,有点感想呀(也有人推荐 Swiftiply,说是性能更好,下一篇我会讲一下简单的配置过程)。

     讲一下我对nginx +mongrel的理解,其实就是nginx 接受公网上的http请求,然后nginx通过反向代理用http协议再把这些请求转发给mongrel,mongrel上启动的Rails对请求进行处理完后再把响应逆向返回,如果如果在高负载的情况下还可以通过mongrel_cluster启动的mongrel集群,并且在nginx上启动负载均衡以成倍的提高处理请求的能力。

    安装步骤:

    1,首先在http://nginx.net/上下载nginx,并安装。(本例安装在 /usr/local/nginx),通过/usr/local/nginx/sbin/nginx 启动,测试,(这个地方我不知道怎么停止nginx服务,只有kill进程)

    2,配置/usr/local/nginx/conf/nginx.conf,如下:

  1. worker_processes  1;   
  2. error_log  logs/error.log debug;   
  3. #error_log  logs/error.log  notice;   
  4. #error_log  logs/error.log  info;   
  5. #pid        logs/nginx.pid;   
  6. events {   
  7.     worker_connections  1024;   
  8. }   
  9. http {   
  10.   include       conf/mime.types;   
  11.   default_type  application/octet-stream;   
  12.   sendfile        on;   
  13.   #tcp_nopush     on;   
  14.   keepalive_timeout  65;   
  15.   tcp_nodelay        on;   
  16.   gzip  on;   
  17.   gzip_min_length  1100;   
  18.   gzip_buffers     4 8k;   
  19.   gzip_types       text/plain;   
  20.   upstream mongrel {   
  21.     server 127.0.0.1:8000;   
  22.     server 127.0.0.1:8001;   
  23.   }   
  24.   server {   
  25.     listen       80;   
  26.     server_name  XXX.XXX.XXX.XXX;  #你可以用你的域名代替以可以是你的对用户发布的IP   
  27.     root /usr/local/depot/public;   
  28.     index  index.html index.htm;   
  29.     location / {   
  30.       proxy_set_header  X-Real-IP  $remote_addr;   
  31.       proxy_set_header  X-Forwarded-For $proxy_add_x_forwarded_for;   
  32.       proxy_set_header Host $http_host;   
  33.       proxy_redirect false;   
  34.       if (-f $request_filename/index.html) {   
  35.         rewrite (.*) $1/index.html break;   
  36.       }   
  37.       if (-f $request_filename.html) {   
  38.         rewrite (.*) $1.html break;   
  39.       }   
  40.       if (!-f $request_filename) {   
  41.         proxy_pass http://mongrel;   
  42.         break;   
  43.       }   
  44.     }   
  45.     error_page   500 502 503 504  /50x.html;   
  46.     location = /50x.html {   
  47.         root   html;   
  48.     }   
  49.   }   
  50. }   

 3,通过下面命令安装mongrel和mongrel_cluster 以上内容我就不用解释了,网上都有

  1. youserver#gem install --include-dependencies mongrel   
  2. youserver#gem install --include-dependencies mongrel_cluster   

   首先测试mongrel是否安装成功。通过应用的主目录(本例/usr/local/depot)下通过mongrel_rails start 启动mongrel服务,用户应该在http://XXX.XXX.XXX.XXX:3000/ 下可以访问到ror的welcome aboard页面。

4,如果以上通过,通过一下命令配置mongrel集群。

  1. mongrel_rails cluster::configure -e development -p 8000  \    
  2. -a 127.0.0.1 -N 2 -c /usr/local/depot   

这句执行后在/usr/local/depot/config目录下应该多一个mongrel_cluster.yml文件,其中内容应该是:

  1. ---    
  2. cwd: /usr/local/depot   
  3. log_file: log/mongrel.log   
  4. port: "8000"  
  5. environment: development   
  6. address: 127.0.0.1  
  7. pid_file: tmp/pids/mongrel.pid   
  8. servers: 2  

 5,在应用主目录下通过命令mongrel_rails cluster::start启动mongrel集群,启动成功后netstat 应该可以看到127.0.0.1的8000和8001处于监听状态。最后启动nginx

6,提供一点简单的测试代码

  1. rugy script/generate controller Say  

编辑 depot/app/controllers/say_controller.rb

ruby 代码
  1. class SayController < ApplicationController   
  2.   def hello   
  3.   end  
  4. end  

编辑depot/app/views/say/hello.rhtml

  1. <html>  
  2. <head>  
  3. <title>Hello,Rails!title>  
  4. head>  
  5. <body>  
  6.     <h1>Hello from Rails!h1>  
  7.     <p>  
  8.         It is nwo <%=Time.now %>  
  9.     p>  
  10. body>  
  11. html>  

 最后,说点自己的感受。

1,通过nginx.conf的配置你可以把http请求反向代理到任何一个内网的已在服务的web server上甚至web service上,很有点SOA的感觉

2,配置简单