Tomcat processes JRuby on Rails request before environment.rb is parsed
-----------------------------------------------------------------------
Key: JRUBY-5179
URL: http://jira.codehaus.org/browse/JRUBY-5179
Project: JRuby
Issue Type: Bug
Affects Versions: JRuby 1.5.2
Environment: SunOS ri-dev1 5.10 Generic_127112-08 i86pc i386 i86pc
Apache Tomcat Version 5.5.26
JRuby 1.5.2
Ruby on Rails 2.3.8
Reporter: Steve Finkelstein
Assignee: Thomas E Enebo
There is an edge case in our implementation of JRuby on Rails where Tomcat
allows processing requests to the application framework before environment.rb
is done parsing. I cannot verify for sure this is the case, however in our
environment.rb where this bug is reproduced consistently, we explicitly require
active_support. If Tomcat is stopped and restarted, we can call a service that
invokes ActiveSupport::TimeZone.all and that will come back nil. We noticed
this as an exception was being thrown and we collected the following backtrace
in our logs:
=== begin backtrace ===
-------------------------------
Backtrace:
-------------------------------
[RAILS_ROOT]/gems/gems/activesupport-2.3.8/lib/active_support/values/time_zone.rb:206:in
`<=>'
[RAILS_ROOT]/gems/gems/activesupport-2.3.8/lib/active_support/values/time_zone.rb:318:in
`sort'
[RAILS_ROOT]/gems/gems/activesupport-2.3.8/lib/active_support/values/time_zone.rb:318:in
`all'
[RAILS_ROOT]/app/controllers/geographies_controller.rb:16:in `timezones'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/base.rb:1331:in
`perform_action'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/filters.rb:617:in
`call_filters'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/filters.rb:638:in
`run_before_filters'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/filters.rb:206:in
`call'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/filters.rb:206:in
`around_proc'
[RAILS_ROOT]/gems/gems/activesupport-2.3.8/lib/active_support/callbacks.rb:182:in
`call'
[RAILS_ROOT]/gems/gems/activesupport-2.3.8/lib/active_support/callbacks.rb:182:in
`evaluate_method'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/filters.rb:184:in
`call'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/filters.rb:635:in
`run_before_filters'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/filters.rb:615:in
`call_filters'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/filters.rb:610:in
`perform_action_with_filters'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/benchmarking.rb:68:in
`perform_action_with_benchmark'
[RAILS_ROOT]/gems/gems/activesupport-2.3.8/lib/active_support/core_ext/benchmark.rb:17:in
`ms'
file:/reuters/coolstack/tomcat5/webapps/insider/WEB-INF/lib/jruby-complete-1.5.2.jar!/META-INF/jruby.home/lib/ruby/1.8/benchmark.rb:308:in
`realtime'
[RAILS_ROOT]/gems/gems/activesupport-2.3.8/lib/active_support/core_ext/benchmark.rb:17:in
`ms'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/benchmarking.rb:68:in
`perform_action_with_benchmark'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/rescue.rb:160:in
`perform_action_with_rescue'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/flash.rb:151:in
`perform_action_with_flash'
[RAILS_ROOT]/vendor/plugins/newrelic_rpm/lib/new_relic/agent/instrumentation/controller_instrumentation.rb:255:in
`perform_action_with_newrelic_trace'
[RAILS_ROOT]/vendor/plugins/newrelic_rpm/lib/new_relic/agent/method_tracer.rb:141:in
`trace_execution_scoped'
[RAILS_ROOT]/vendor/plugins/newrelic_rpm/lib/new_relic/agent/instrumentation/controller_instrumentation.rb:248:in
`perform_action_with_newrelic_trace'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/base.rb:532:in
`process'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/filters.rb:606:in
`process_with_filters'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/base.rb:391:in
`process'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/base.rb:386:in
`call'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/routing/route_set.rb:438:in
`call'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/dispatcher.rb:87:in
`dispatch'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/dispatcher.rb:121:in
`_call'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/dispatcher.rb:130:in
`build_middleware_stack'
[RAILS_ROOT]/app/middleware/flash_session_cookie_middleware.rb:29:in `call'
[RAILS_ROOT]/app/middleware/flash_session_cookie_middleware.rb:29:in `call'
[RAILS_ROOT]/app/middleware/set_cookie_domain.rb:16:in `call'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/string_coercion.rb:25:in
`call'
[RAILS_ROOT]/gems/gems/rack-1.1.0/lib/rack/head.rb:9:in `call'
[RAILS_ROOT]/lib/rack_method_override_patch.rb:24:in `call'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/params_parser.rb:15:in
`call'
[RAILS_ROOT]/gems/gems/rails-2.3.8/lib/rails/rack/metal.rb:47:in `call'
[RAILS_ROOT]/app/middleware/set_cookie_domain.rb:16:in `call'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/session/abstract_store.rb:128:in
`call'
[RAILS_ROOT]/app/middleware/flash_session_cookie_middleware.rb:29:in `call'
[RAILS_ROOT]/gems/gems/activerecord-2.3.8/lib/active_record/query_cache.rb:29:in
`call'
[RAILS_ROOT]/gems/gems/activerecord-2.3.8/lib/active_record/connection_adapters/abstract/query_cache.rb:34:in
`cache'
[RAILS_ROOT]/gems/gems/activerecord-2.3.8/lib/active_record/query_cache.rb:9:in
`cache'
[RAILS_ROOT]/gems/gems/activerecord-2.3.8/lib/active_record/query_cache.rb:28:in
`call'
[RAILS_ROOT]/gems/gems/activerecord-2.3.8/lib/active_record/connection_adapters/abstract/connection_pool.rb:361:in
`call'
[RAILS_ROOT]/gems/gems/activesupport-2.3.8/lib/active_support/cache/strategy/local_cache.rb:36:in
`call'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/failsafe.rb:26:in
`call'
[RAILS_ROOT]/gems/gems/actionpack-2.3.8/lib/action_controller/dispatcher.rb:106:in
`call'
file:/reuters/coolstack/tomcat5/webapps/insider/WEB-INF/lib/jruby-rack-0.9.5.jar!/rack/adapter/rails.rb:35:in
`serve_rails'
file:/reuters/coolstack/tomcat5/webapps/insider/WEB-INF/lib/jruby-rack-0.9.5.jar!/rack/adapter/rails.rb:40:in
`call'
file:/reuters/coolstack/tomcat5/webapps/insider/WEB-INF/lib/jruby-rack-0.9.5.jar!/jruby/rack/rails.rb:148:in
`call'
file:/reuters/coolstack/tomcat5/webapps/insider/WEB-INF/lib/jruby-rack-0.9.5.jar!/rack/handler/servlet.rb:18:in
`call'
:1
=== end backtrace ===
If you make subsequent requests, the invocation to the web service works fine,
because one can assume at that point ActiveSupport was loaded into memory and
can be accessed. The exception never gets thrown again, only reproduced when we
restart Tomcat.
some more relevant information from newrelic:
* action_controller.request.path_parameters :
controllergeographiesactiontimezonesformatxml
* action_controller.request.query_parameters :
* action_controller.request.request_parameters:
* action_controller.rescue.request :
#<ActionController::Request:0x384af712>
* action_controller.rescue.response :
#<ActionController::Response:0x41a2db9d>
* java.servlet_context :
org.jruby.rack.servlet.servletrackcont...@5492de02
* java.servlet_request :
org.apache.catalina.connector.requestfac...@145c38c1
* jruby.rack.dynamic.requests.only : true
* jruby.rack.jruby.version : 1.5.2
* jruby.rack.rack.release : 1.1
* jruby.rack.version : 0.9.5
* rack.errors :
#<JRuby::Rack::ServletLog:0x2b004215>
* rack.input :
#<JRuby::RackRewindableInput:0x1df286c1>
* rack.multiprocess : false
* rack.multithread : true
* rack.request.query_hash :
* rack.request.query_string :
* rack.run_once : false
* rack.session.record :
#<ActiveRecord::SessionStore::Session:0x13b2558e>
* rack.url_scheme : http
* rack.version : 11
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators:
http://jira.codehaus.org/secure/Administrators.jspa
-
For more information on JIRA, see: http://www.atlassian.com/software/jira
---------------------------------------------------------------------
To unsubscribe from this list, please visit:
http://xircles.codehaus.org/manage_email