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方法