18

我正在开发移动/VOIP 域中的应用程序。这对我来说真的是一个灰色地带。以下是有关该应用程序的一些详细信息:

  • 这基本上就像自动充值/预付费移动服务
  • 与我之前编写的 ERP 应用程序相比,将具有中等复杂性的逻辑。
  • 响应中的视图部分将是纯文本,将作为 SMS/USSD pull 发送给用户,语音 XML (VXML) 将作为 IVR 响应发送给用户。
  • 路由逻辑非常简单,因为对于每种类型的回复只有两到三个 URL 是重要的。

约束:

我们有在 Perl 中构建的核心系统(它是一个服务于许多其他 VOIP/移动相关服务的遗留系统),以及一个跟踪损益的会计系统,但它已经变得非常复杂。所以我们决定单独做这个应用,只使用 SMS/USSD 和 IVR。但是,此应用程序的每个用户都必须是核心系统的注册用户,以用于会计目的;这我们可以通过 API 调用轻松实现。

现在,为了发送 IVR 和 USSD 的回复/响应,我们需要在提供这些设施的供应商处部署应用程序。但是我们不希望总是需要登录到他们的服务器以获取每日报告和会计资料,因为对于我们的每个客户,我们将有不同的 USSD/SMS/IVR 系统流程。

所以,我们决定这个新应用确实会分成两个子应用。

  • 一个应用程序将处理具有 USSD/SMS/IVR 域的用户接口,并将部署在供应商的服务器上,我们将其称为“客户端软件”。
  • 第二个应用程序将处理所有核心业务逻辑和报告系统,并将部署在我们的服务器上,我们将拥有完全访问权限。我们将其称为“中间件”。

申请的基本流程:

  1. 用户拨打简码。
  2. 呼叫登陆我们的供应商服务器,客户端应用程序将在其中处理请求并将其注册为本地数据库中的用户。
  3. 客户端也会对中间件进行 API 调用。在那边注册这个用户以及核心业务逻辑及时自动充值等。
  4. 然后,中间件还将对核心系统进行 API 调用,以便在该处注册该用户以及用于记帐目的。

现在,将有许多这样的客户端应用程序与单个中间件应用程序交互。我们决定用 Ruby 构建这些应用程序。我会为此遵循 RESTful 架构,因为涉及到很多 API 调用。

在这三个框架中,RailsPadrinoSinatra,它们中的任何一个特别适合这个项目吗?如果可能的话,我将不胜感激详细的相关利弊。

4

1 回答 1

83

我是 Padrino 的创建者之一,但我也与 Rails 和 Sinatra 进行了广泛的合作。可能不是您想听到的,但无论您选择什么,您都可以相当轻松地完成这个项目。我不能说选择一个会比在宏伟计划中选择其他任何一个对您产生更大的影响。

我显然是 Rack 和 Sinatra 模块化和轻量级特性的支持者。在 Rack、Rack Middlewares、Sinatra 和扩展之间,如果您愿意了解这些工具,您可以像在 Rails 中一样轻松地完成任何事情。

我认为 Sinatra 和 Padrino 对 Ruby 新手的学习曲线较低。这是因为他们提倡“采取你需要的东西”和“渐进式复杂性”比“一次性完成”的 Rails 方法要好得多,但另一方面,Rails 有更多的文档、博客、支持等。所以交易关闭是明确的。Sinatra 和 Padrino 在内存占用、每秒请求数、cpu 使用率等方面也“更快”和“更轻”,但 Rails 在大多数情况下都足够快,而且应用程序服务器很少成为瓶颈。

说了这么多,我会尽量给你一个更直接的意见。如果您只做一个服务 API(听起来像这里),我会推荐使用 Sinatra、Padrino 甚至我们的 Renee over Rails 的另一个项目。对于轻量级服务 API,Rails 对大多数衡量标准来说都是多余的。

进一步缩小范围,Padrino是 Sinatra,因此您不必在它们之间进行选择。您可以从 Sinatra 开始并包含来自 Padrino 的独立模块,或者使用完整的 Padrino 应用程序,该应用程序在底层仍然是 Sinatra,访问许多强大功能(i18n、记录器、管理面板、缓存)的性能损失非常小、生成器、表单助手、邮件程序等)。请记住,这些都是“仅在需要时才使用它们”的模块化扩展。

I would recommend checking out our Padrino Getting Started guide for a place to start exploring Sinatra and Padrino. Our Padrino guides and documentation strive to be thorough. That said, the "safe" bet is Rails since it has a lot more usage, it is more mature, has more contributors and a lot more documentation / googleability. Good luck, hope this was helpful.

于 2011-11-11T11:05:41.603 回答