即使使用模块化风格实现默认路由,Sinatra也不会知道这个小曲

时间:2015-01-17 23:39:43

标签: ruby sinatra jruby modular

我正在jruby运行MacOS小牛,我正在尝试编写一个基本的modular sinatra应用。这是我config.ru的样子

require 'app/app'   
run Sinatra::Application

我使用rackup调用它,您可以看到404错误 -

rackup -s puma -p 8080
Puma 2.10.2 starting...
* Min threads: 0, max threads: 16
* Environment: development
* Listening on tcp://localhost:8080
127.0.0.1 - - [17/Jan/2015:18:32:37 -0500] "GET / HTTP/1.1" 404 437 0.0290
127.0.0.1 - - [17/Jan/2015:18:32:37 -0500] "GET / HTTP/1.1" 404 437 0.0980
127.0.0.1 - - [17/Jan/2015:18:32:37 -0500] "GET /__sinatra__/404.png HTTP/1.1" 304 - 0.0120
127.0.0.1 - - [17/Jan/2015:18:32:37 -0500] "GET /__sinatra__/404.png HTTP/1.1" 304 - 0.0170

这就是我source的样子 -

➜ less app/app.rb
require 'sinatra/base'

class App < Sinatra::Base

  get '/' do
    "Hello World"
  end
end

如果我将源更改为经典方式

➜ cat app/app.rb
require 'sinatra'

#class App < Sinatra::Base

  get '/' do
    "Hello World"
  end
#end

然后像这样调用它,它工作得很好 -

➜ ruby app/app.rb
Puma 2.10.2 starting...
* Min threads: 0, max threads: 16
* Environment: development
* Listening on tcp://localhost:4567
== Sinatra/1.4.5 has taken the stage on 4567 for development with backup from Puma
127.0.0.1 - - [17/Jan/2015:18:36:20 -0500] "GET / HTTP/1.1" 200 11 0.0250

我想我错过了一些非常明显的配置,但似乎可以弄清楚那是什么,有人能让我知道我错过了什么吗?如果需要,我可以分享有关环境的更多细节。

1 个答案:

答案 0 :(得分:4)

当您使用模块化样式时,Sinatra::Application应用程序仍然存在,但通常没有任何反应。在您的config.ru中,您正在运行此(空)应用而不是您自己的应用。只需将run Sinatra::Application更改为

即可
run App