#tomcat #sinatra #jruby #openshift #warbler
#tomcat #sinatra #jruby #openshift #warbler
Вопрос:
Я создал приложение с использованием Sinatra (JRuby 1.7.13, Ruby-1.9). Приложение основано на стойке и использует MySQL в серверной части.
Я использовал warbler для создания файла war и успешно развернул его на своем локальном tomcat. Все работает отлично!
Но когда я отправил этот файл war в openshift (следуя всей процедуре, описанной в базе знаний openshift). Но tomcat показывает ошибку 404. Я заглянул в файл журнала. Я прикрепляю здесь gyst этого огромного файла —
--- Backtrace
LoadError: no such file to load -- sinatra
require at org/jruby/RubyKernel.java:1065
require at file:/var/lib/openshift/53a807dfe0b8cd33450000c4/jbossews/work/Catalina
/localhost/_/WEB-INF/lib/jruby-stdlib-complete-1.7.13.jar!/META-INF/jruby.home/lib/ruby
/shared/rubygems/core_ext/kernel_require.rb:55
(root) at /localhost/WEB-INF/config.ru:2
instance_eval at org/jruby/RubyBasicObject.java:1533
initialize at file:/var/lib/openshift/53a807dfe0b8cd33450000c4/jbossews/work/Catalina/localhost/_/WEB-INF/lib/jruby-rack-1.1.14.jar!/vendor/rack-1.4.5/rack/builder.rb:51
(root) at /localhost/WEB-INF/config.ru:1
…
SEVERE: ERROR: initialization failed
org.jruby.rack.RackInitializationException: no such file to load -- sinatra
from org/jruby/RubyKernel.java:1065:in `require'
from file:/var/lib/openshift/53a807dfe0b8cd33450000c4/jbossews/work/Catalina/localhost/_/WEB-INF/lib/jruby-stdlib-complete-1.7.13.jar!/META-INF/jruby.home/lib/ruby/shared/rubygems/core_ext/kernel_require.rb:55:in `require'
from /localhost/WEB-INF/config.ru:2:in `(root)'
from org/jruby/RubyBasicObject.java:1533:in `instance_eval'
from file:/var/lib/openshift/53a807dfe0b8cd33450000c4/jbossews/work/Catalina/localhost/_/WEB-INF/lib/jruby-rack-1.1.14.jar!/vendor/rack-1.4.5/rack/builder.rb:51:in `initialize'
from /localhost/WEB-INF/config.ru:1:in `(root)'
at org.jruby.rack.RackInitializationException.wrap(RackInitializationException.java:29)
at org.jruby.rack.RackApplicationFactoryDecorator.init(RackApplicationFactoryDecorator.java:104)
at org.jruby.rack.RackServletContextListener.contextInitialized(RackServletContextListener.java:50)
…. и ….
Caused by: org.jruby.exceptions.RaiseException: (LoadError) no such file to load -- sinatra
at org.jruby.RubyKernel.require(org/jruby/RubyKernel.java:1065)
at RUBY.require(file:/var/lib/openshift/53a807dfe0b8cd33450000c4/jbossews /work/Catalina/localhost/_/WEB-INF/lib/jruby-stdlib-complete-1.7.13.jar!/META-INF/jruby.home /lib/ruby/shared/rubygems/core_ext/kernel_require.rb:55)
at RUBY.(root)(/localhost/WEB-INF/config.ru:2)
at org.jruby.RubyBasicObject.instance_eval(org/jruby/RubyBasicObject.java:1533)
at RUBY.initialize(file:/var/lib/openshift/53a807dfe0b8cd33450000c4/jbossews/work/Catalina/localhost/_/WEB-INF/lib/jruby-rack-1.1.14.jar!/vendor/rack-1.4.5/rack/builder.rb:51)
Вопрос в том, что мне следует сделать, чтобы развернуть сгенерированный warber файл war для развертывания в tomcat на сервере openshift? Этот материал отлично работает в локальном tomcat.
Большое спасибо!
Комментарии:
1. Согласно трассировкам стека, я бы сказал, что вы не запускаете bunlder
2. @Sirl33tname: я использую bundler и rackup