Ruby on Rails 正式引入 Metal

  • Robert Bazinet
  • 李明(nasi)

2008 年 12 月 25 日

话题:RubyWeb框架Ruby on Rails语言 & 开发

Ruby on Rails团队正忙于采用Rack将 Rails 推升至新的高度。Rack 的实现方式使得开发者可以在自己的应用中使用许多现成的中间件,而这种特性使得 Rails 团队开发 Metal 成为可能。Metal 是通用 Rack 中间件的包装,放置在 Rails 请求之前,并且可以访问 Rails 的会话。对于那些要求运行速度非常快,需要每秒处理成百上千个请求的应用来说,Metal 简直就是量身定做的一般。

David Heinemeier HanssonRuby on Rails 的官方博客上正式宣布引入 Rails Metal,并举例说明了其适用范围:

目前为止我们已经实现了一个轻量级的包装器,它封装了通用 Rack 中间件,并命名为"Metal"。 Rails Metal 对类似与Campfire投票服务的应用非常有用,Campfire 每秒需要处理成百上千的请求,速度要求非常快,同时其逻辑又很简单(2 个数据库调用然后返回一个字符串)。目前这个服务是用 C 编写的,不过我们将会看到,它很快将会被 Rails Metal 所取代。

Jesse Newland 也发表了一篇名为Rails Metal:借 Rails 之力的微框架的博文,其中写到:

最近我们用Rack取代了 Rails 原有的请求处理代码,并且集成了中间件的支持,Rails Metal 是一项睿智的改进,它允许 Rails 应用使用 Rack 中间件来创建一个超级快的 action。

Jesse 提供了 Rails Metal 的“hello word”的例子,并与普通的 Rails 控制器做了比较:

class Poller < Rails::Rack::Metal
    def call(env)
      if env["PATH_INFO"] =~ /^\/poller/
        [[200], {"Content-Type" => "text/html"}, "Hello, World!"]
      else
        [[404], {"Content-Type" => "text/html"}, "Not Found"]
      end
    end
end

普通的 Rails 控制器:

class OldPollerController < ApplicationController
      def poller
        render :text => "Hello World!"
      end
end

这两段代码迥异,在一个简单的基准测试上的结果是:Metal 比老版本的 controller 快 25 倍。

InfoQ 采访了 Rails 核心团队成员、Rails Metal 的开发者Joshua Peek,了解到了一些这个前景一片光明的新兴技术的细节。

当被问道 Rails Metal 是什么时,Joshua 回答说:

Rails Metal 应用是一种面向特定类型的应用,小而且快。它们可以和 Rails 应用在相同的进程里运行,这意味着它应该很容易开发,或者你也可以单独部署。

哪些类型的问题适合使用 Rail Metal 来解决?

Metal 适用于构建需要每秒处理成百上千请求的微型服务。

Rails Metal 是一种新技术,并不是人人都适用,那么 Metal 对于一般的 Rails 开发者来说有什么价值呢?

虽然对于任何一个 Rails 开发者来说,建立 metal 应用都是件非常容易的事,但是它确实是一件利器。Rails 开发者还是应该继续按照原来的方式使用 Rails,当他们确认某个特定的 action 有特别高的性能要求时,Metal 就能派上用场了。

Metal 似乎是用到了最新的 Rack 实现最本质的功能,但是实际上,Rails 引入 Metal 的目的却并不在此,就此 Josh 解释说:

Rails 提供了一个全栈的 MVC 框架,包罗万象,你可以用来构建一个真正的应用。然而,Rails 也允许你使用“metal”来实现最快的速度。无论是两者中的哪一个,我们都希望给开发者提供最好的支持。

有意思的是,人们在看到Merb-Core时,可能会拿它和 Metal 做比较,而事实上两者迥然不同。

Merb 是一个完整的 MVC 框架。然而,Metal 就不是那么有血有肉了。它简化了 Rack API,你得到的是一个原始的请求环境散列,你需要返回一个状态码,应答包头和一个应答包体。在 Metal 里面没有控制器或者视图的概念,开发者可以用最少的代码来实现想要的功能。

我们已经听过很多微框架及其适用范围了。Jesse Newland 把 Metal 和其他的“微框架”相提并论。我们询问了 Joshua,Metal 是否会造成其他的微框架的需求降低:

不会的。对于像 Sinatra 这类微框架来说,还有一定的空间,把它做得足够简单,来编写简单的 API 处理程序。事实上,你可以把 Sinatra 当成一个 metal 应用来使用。因为 Sinatra 构建于 Rack 之上,所以会工作的很好。

最后,开发者如何才能获取到 Metal?

现在 Edge Rails 已经引入了 Metal。或者你也可以等 Rails 的下一个 gem 发布,应该是 2.3 版。

Rails Metal 的发布已经引起了广泛的关注,它给需要速度的 Rails 应用带来了好消息。更多关于 Rails Metal 的信息,请访问Ruby on Rails 官方博客以及GitHub 代码库,你可以从 Github 库中获取 Rails。

查看英文原文:Ruby on Rails gets down to the Metal

RubyWeb框架Ruby on Rails语言 & 开发