私はRubyの世界の初心者です。いくつかの調査を行った後、デモRailsアプリケーションを生成し、Webrickサーバーでテストできます
しかし、Tomcat でデプロイを開始すると問題が発生しました。warbler を使用してデプロイ用の war ファイルをエラーなしで正常に生成します。Tomcat 7.0 の webapps のフォルダーの下に war をコピーします。サーバーを起動し、ブラウザーで実行しようとすると、アセットが見つかりました。ファイルにアクセスできず、コントローラー メソッドは正しいビューにリダイレクトできませんが、「申し訳ありませんが、問題が発生しました」と表示されます。メッセージ
私が試した展開の構成
JRuby 1.7.0 宝石 jruby ラック 1.1.10、1.0.10 レール 3.2.9、3.2.0 ウグイス 1.3.6、1.3.2 トムキャット 7.0.32
tomcatのアクセスログはこちら
127.0.0.1 - - [20/11/2012:13:56:38 +0800] "GET /demo/HTTP/1.1" 200 5906 127.0.0.1 - - [20/11/2012:13:56:49 +0800] "GET /demo/assets/rails.png HTTP/1.1" 404 728 127.0.0.1 - - [20/11/2012:14:01:21 +0800] "GET /demo/order/add HTTP/1.1" 500 643
これがログフォームのTomcatです
2012/11/20 13:56:18 org.apache.catalina.core.ApplicationContext ログ INFO: jruby 1.7.0 (1.9.3p203) 2012-10-22 ff1ebbe on Java HotSpot(TM) Client VM 1.6.0_34-b04 [Windows XP-x86] 2012/11/20 13:56:18 org.apache.catalina.core.ApplicationContext ログ INFO: using: 取得タイムアウトが 10.0 秒のランタイム プール 2012/11/20 13:56:19 org.apache.catalina.core.ApplicationContext ログ ContextListener: contextInitialized() 2012/11/20 13:56:19 org.apache.catalina.core.ApplicationContext ログ SessionListener: contextInitialized() 2012/11/20 13:56:19 org.apache.catalina.core.ApplicationContext ログ ContextListener: attributeAdded('org.apache.jasper.compiler.TldLocationsCache', 'org.apache.jasper.compiler.TldLocationsCache@1858aa0') 2012/11/20 01:56:38 org.apache.catalina.core.ApplicationContext ログ 情報: プールが空でした - 新しいアプリケーション インスタンスを取得しています 2012/11/20 01:56:47 org.apache.catalina.core.ApplicationContext ログ 2012-11-20 13:56:47 +0800 で 127.0.0.1 の GET "/demo/assets/rails.png" を開始しました 2012/11/20 01:56:47 org.apache.catalina.core.ApplicationContext ログ database.yml で指定されたデータベースに接続する 2012/11/20 01:56:49 org.apache.catalina.core.ApplicationContext ログ ActionController::RoutingError ([GET] "/assets/rails.png" に一致するルートはありません): gems/gems/actionpack-3.2.9/lib/action_dispatch/middleware/debug_exceptions.rb:21:in `call' gems/gems/actionpack-3.2.9/lib/action_dispatch/middleware/show_exceptions.rb:56:in `call' gems/gems/railties-3.2.9/lib/rails/rack/logger.rb:32:in `call_app' gems/gems/railties-3.2.9/lib/rails/rack/logger.rb:16:in `call' gems/gems/activesupport-3.2.9/lib/active_support/tagged_logging.rb:22:「タグ付き」で gems/gems/railties-3.2.9/lib/rails/rack/logger.rb:16:in `call' gems/gems/actionpack-3.2.9/lib/action_dispatch/middleware/request_id.rb:22:in `call' gems/gems/rack-1.4.1/lib/rack/methodoverride.rb:21:in `call' gems/gems/rack-1.4.1/lib/rack/runtime.rb:17:in `call' gems/gems/activesupport-3.2.9/lib/active_support/cache/strategy/local_cache.rb:72:in `call' gems/gems/rack-1.4.1/lib/rack/lock.rb:15:in `call' gems/gems/rack-cache-1.2/lib/rack/cache/context.rb:136:「進む」 gems/gems/rack-cache-1.2/lib/rack/cache/context.rb:245:in `fetch' gems/gems/rack-cache-1.2/lib/rack/cache/context.rb:185:in `ルックアップ' gems/gems/rack-cache-1.2/lib/rack/cache/context.rb:66:in `call!' gems/gems/rack-cache-1.2/lib/rack/cache/context.rb:51:in `call' gems/gems/railties-3.2.9/lib/rails/engine.rb:479:in `call' gems/gems/railties-3.2.9/lib/rails/application.rb:223:in `call' file:/lib/jruby-rack-1.1.10.jar!/rack/handler/servlet.rb:22:in `call' 2012/11/20 14:01:21 org.apache.catalina.core.ApplicationContext ログ 2012-11-20 14:01:21 +0800 で 127.0.0.1 の GET "/demo/order/add" を開始しました 2012/11/20 14:01:21 org.apache.catalina.core.ApplicationContext ログ OrderController#add as HTMLによる処理 2012/11/20 14:01:21 org.apache.catalina.core.ApplicationContext ログ レイアウト/アプリケーション内で order/add.html.erb をレンダリング (16.0ms) 2012/11/20 14:01:21 org.apache.catalina.core.ApplicationContext ログ 78 ミリ秒で 500 内部サーバー エラーを完了
ルーティングの問題が発生しているようですが、RailsアプリケーションをROOT以外の場所にデプロイした場合の問題でしょうか?
これと同様のトピックを調査しました。以下のコマンドを production.rb に追加するなどの解決策を試しましたが、助けにはなりません。
config.action_controller.relative_url_root = "/demo"
解決策をありがとう