rails2.2.2漫步

rails启动:

require File.dirname(__FILE__) + '/../config/boot'这行代码执行一下操作:
  1、先判断是vender启动还是gem启动
  2、gem启动,加载rubygems,再加载rails,rails版本号从environment.rb获得
  3、加载完rails后,require 'initializer'
  4、最后执行Rails::Initializer.run(:set_load_path)
  5、最后执行set_load_path方法,即设置一些加载路径

require 'commands/server'  这行代码执行以下操作:
  1、选择启动的server:thin,mongrel,webrick,lighttpd
  2、创建tmp下面的文件夹:cache pids sessions sockets
  3、加载对应的server文件,如:thin就加载thin的文件
  4、日志的输出是用一个线程tail_thread每秒输出一次,如果有新日志的话

加载thin的文件后执行如下语句
thin = Thin::Runner.new(options)
thin.run!
这样thin就启动了。

thin是通过rack的方式来进行处理的,因此rails2.2.3之前thin里面有对rails的adapter,即一个rack包装,2.2.3之后rails本身支持rack。
thin的服务程序使用eventmachine。

thin的启动过程:
选择controller方式:cluster/service/controller  3种
以controller为例:
调用controller.start,在start方法里面,新建一个Server对象
然后
        if @options[:rackup]
          server.app = load_rackup_config
        else
          server.app = load_adapter
        end

这里server.app就是一个rails对象,是Rack::Adapter::Rails类,不是我们所说的rails哦。
rails.rails_app是一个CgiApp或者ActionController::Dispatcher。
rails对象和CigApp两者都是一个rack程序,都有call方法
因此,这样当eventmachine接受到数据时,就调用server.app.call即rails.call方法,rails.call方法里调用rails_app.call,这就是rack的层级调用。rails_app.call方法:
        class CgiApp
          def call(env)
            request         = Request.new(env)
            response        = Response.new
            session_options = ActionController::CgiRequest::DEFAULT_SESSION_OPTIONS
            cgi             = CGIWrapper.new(request, response)

            Dispatcher.dispatch(cgi, session_options, response)

            response.finish
          end
        end

这里就可以看到调用了大名鼎鼎的Dispatcher.dispatch方法



你可能感兴趣的:(lighttpd,Ruby,Rails,rubygems,rack)