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