编辑:我让应用程序使用 TorqueBox 工作,所以我猜这个问题与特立尼达有关。但是,我认为我对运行 Sinatra 应用程序的首选方式的猜测仍然有效。
我正在使用 JRuby、Bundler 和模块化风格。这是我的应用程序代码:
# myapp.rb
class MyApp < Sinatra::Base
configure :development do
register Sinatra::Reloader
end
set :server, 'trinidad'
set :environment, :development
set :logging, true
#...
end
# config.ru
require 'bundler/setup'
Bundler.require(:default)
$: << File.dirname(__FILE__)
require 'myapp'
run MyApp
# Gemfile
source 'http://rubygems.org'
gem 'rack'
gem 'sinatra', :require => 'sinatra/base'
gem 'sinatra-contrib', :require => 'sinatra/reloader'
gem 'coffee-script'
gem 'neography'
gem 'gon-sinatra'
gem 'sass'
gem 'trinidad'
启动我的应用程序的正确方法是什么(即什么样的命令)?我正在使用 Trinidad,因为我读到它是 JRuby 应用程序的好解决方案(我无法让 TorqueBox 工作)。目前我正在通过“trinidad config.ru”运行我的应用程序,但它会引发以下错误消息:
application error
org.jruby.rack.RackInitializationException: no such file to load -- bundler/setup
from org/jruby/RubyKernel.java:991:in `require'
from /home/myhome/.rvm/rubies/jruby-1.7.0.preview1/lib/ruby/shared/rubygems/custom_require.rb:36:in `require'
from /home/myhome/RubymineProjects/myapp/config.ru:1:in `(root)'
from org/jruby/RubyBasicObject.java:1818:in `instance_eval'
from jar:file:/home/myhome/.rvm/gems/jruby-1.7.0.preview1/gems/jruby-rack-1.1.9/lib/jruby-rack-1.1.9.jar!/vendor/rack-1.4.1/rack/builder.rb:51:in `initialize'
from /home/myhome/RubymineProjects/myapp/config.ru:1:in `(root)'
at org.jruby.rack.DefaultRackApplicationFactory$4.init(DefaultRackApplicationFactory.java:224)
at org.jruby.rack.DefaultRackApplicationFactory.getApplication(DefaultRackApplicationFactory.java:58)
at org.jruby.rack.PoolingRackApplicationFactory.createApplication(PoolingRackApplicationFactory.java:323)
at org.jruby.rack.PoolingRackApplicationFactory.getApplication(PoolingRackApplicationFactory.java:171)
at org.jruby.rack.DefaultRackDispatcher.getApplication(DefaultRackDispatcher.java:27)
at org.jruby.rack.AbstractRackDispatcher.process(AbstractRackDispatcher.java:32)
at org.jruby.rack.AbstractServlet.service(AbstractServlet.java:37)
at org.jruby.rack.AbstractServlet.service(AbstractServlet.java:43)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:225)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1001)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:579)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:310)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603)
at java.lang.Thread.run(Thread.java:722)
Caused by: org.jruby.exceptions.RaiseException: (LoadError) no such file to load -- bundler/setup
at org.jruby.RubyKernel.require(org/jruby/RubyKernel.java:991)
at Kernel.require(/home/myhome/.rvm/rubies/jruby-1.7.0.preview1/lib/ruby/shared/rubygems/custom_require.rb:36)
at RUBY.(root)(/home/myhome/RubymineProjects/myapp/config.ru:1)
at org.jruby.RubyBasicObject.instance_eval(org/jruby/RubyBasicObject.java:1818)
at RUBY.initialize(jar:file:/home/myhome/.rvm/gems/jruby-1.7.0.preview1/gems/jruby-rack-1.1.9/lib/jruby-rack-1.1.9.jar!/vendor/rack-1.4.1/rack/builder.rb:51)
at RUBY.(root)(/home/myhome/RubymineProjects/myapp/config.ru:1)
ignoring null application
我正在使用 Trinidad and Rack 的 1.4.1 版本、JRuby 的 1.7.0.preview1 和 Sinatra 的 1.3.3 版本。
如果我运行“bundle exec trinidad config.ru”,我会收到以下错误:
application error
org.jruby.rack.RackInitializationException: Valid types are [:development, :runtime],
from /home/myhome/.rvm/rubies/jruby-1.7.0.preview1/lib/ruby/shared/rubygems/dependency.rb:45:in `initialize'
from /home/myhome/.rvm/rubies/jruby-1.7.0.preview1/lib/ruby/shared/rubygems/specification.rb:821:in `add_dependency_with_type'
from :1:in `'
from :1:in `'
from org/jruby/RubyKernel.java:1037:in `eval'
from org/jruby/RubyArray.java:1611:in `each'
from org/jruby/RubyArray.java:1611:in `each'
from org/jruby/RubyEnumerable.java:649:in `find_all'
from org/jruby/RubyKernel.java:991:in `require'
from org/jruby/RubyKernel.java:991:in `require'
from org/jruby/RubyKernel.java:991:in `require'
at org.jruby.rack.DefaultRackApplicationFactory.createApplication(DefaultRackApplicationFactory.java:235)
at org.jruby.rack.DefaultRackApplicationFactory.newApplication(DefaultRackApplicationFactory.java:49)
at org.jruby.rack.DefaultRackApplicationFactory.getApplication(DefaultRackApplicationFactory.java:57)
at org.jruby.rack.PoolingRackApplicationFactory.createApplication(PoolingRackApplicationFactory.java:323)
at org.jruby.rack.PoolingRackApplicationFactory.getApplication(PoolingRackApplicationFactory.java:171)
at org.jruby.rack.DefaultRackDispatcher.getApplication(DefaultRackDispatcher.java:27)
at org.jruby.rack.AbstractRackDispatcher.process(AbstractRackDispatcher.java:32)
at org.jruby.rack.AbstractServlet.service(AbstractServlet.java:37)
at org.jruby.rack.AbstractServlet.service(AbstractServlet.java:43)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:225)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1001)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:579)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:310)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603)
at java.lang.Thread.run(Thread.java:722)
Caused by: org.jruby.exceptions.RaiseException: (ArgumentError) Valid types are [:development, :runtime],
at Gem::Dependency.initialize(/home/myhome/.rvm/rubies/jruby-1.7.0.preview1/lib/ruby/shared/rubygems/dependency.rb:45)
at Gem::Specification.add_dependency_with_type(/home/myhome/.rvm/rubies/jruby-1.7.0.preview1/lib/ruby/shared/rubygems/specification.rb:821)
at RUBY.(:1)
at RUBY.(:1)
at org.jruby.RubyKernel.eval(org/jruby/RubyKernel.java:1037)
at org.jruby.RubyArray.each(org/jruby/RubyArray.java:1611)
at org.jruby.RubyArray.each(org/jruby/RubyArray.java:1611)
at org.jruby.RubyEnumerable.find_all(org/jruby/RubyEnumerable.java:649)
at org.jruby.RubyKernel.require(org/jruby/RubyKernel.java:991)
at org.jruby.RubyKernel.require(org/jruby/RubyKernel.java:991)
at org.jruby.RubyKernel.require(org/jruby/RubyKernel.java:991)
ignoring null application