【问题标题】:Deploy jruby project to tomcat in windows platformwindows平台下jruby项目部署到tomcat
【发布时间】:2023-03-18 15:48:01
【问题描述】:

我是 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 - - [2012 年 11 月 20 日:13:56:38 +0800] “GET /demo/HTTP/1.1”200 5906 127.0.0.1 - - [2012 年 11 月 20 日:13:56:49 +0800] “GET /demo/assets/rails.png HTTP/1.1”404 728 127.0.0.1 - - [2012 年 11 月 20 日: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 日志 信息:Java HotSpot(TM) 客户端 VM 1.6.0_34-b04 [Windows XP-x86] 上的 jruby 1.7.0 (1.9.3p203) 2012-10-22 ff1ebbe 2012/11/20 13:56:18 org.apache.catalina.core.ApplicationContext 日志 信息:使用:运行时池,获取超时为 10.0 秒 2012/11/20 13:56:19 org.apache.catalina.core.ApplicationContext 日志 上下文监听器:上下文初始化() 2012/11/20 13:56:19 org.apache.catalina.core.ApplicationContext 日志 会话监听器: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 获取“/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:in `tagged' 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:in `forward' 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 `lookup' 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' 文件:/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 获取“/demo/order/add” 2012/11/20 14:01:21 org.apache.catalina.core.ApplicationContext 日志 由 OrderController#add 作为 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 内部服务器错误

好像是路由问题,是不是我在ROOT位置以外部署rails应用的时候出现的问题?

我研究过类似的主题,我尝试了一些解决方案,例如 在 production.rb 中添加以下命令,但没有帮助。

config.action_controller.relative_url_root = "/demo"

感谢您的解决方案

【问题讨论】:

  • +1 ...我已经预编译了我的资产,但需要设置 config.action_controller.relative_url_root

标签: ruby-on-rails tomcat jruby warbler


【解决方案1】:

在warbling之前你是否预编译了你的资产?

在运行warble之前需要运行rake assets:precompile生成静态内容

【讨论】:

  • 非常感谢,它有效。每次更改资产文件夹后我都需要运行命令吗?
  • 是的,有点麻烦。编译资产需要很长时间。对于开发人员,我们通常在本地运行 rails server。我们仅为 QA 和 PROD 服务器编译资产和 warble。这是由我们的 CI 完成的。
  • 还有一件更重要的事情:如果您在本地 dev 文件夹中编译资产并运行 rails server,它将获取您的资产两次。来自 app/assets 和 public/assets。您需要在运行rails server 之前清理已编译的资产。 rake assets:clean 应该做的工作
  • 再次感谢,您的建议很宝贵
  • @arkadiy +1 for > rake assets:clean
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-10-03
  • 1970-01-01
  • 2016-11-12
  • 2012-03-01
  • 1970-01-01
相关资源
最近更新 更多