- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 ruby 世界的新手,经过一些研究后,我可以生成一个演示 rails 应用程序并在 webrick 服务器上进行测试
但是开始用tomcat部署的时候遇到了问题我使用 warbler 生成 war 文件部署成功没有错误将war复制到Tomcat 7.0的webapps文件夹下启动服务器并尝试在浏览器上运行我发现 Assets 文件不可访问并且 Controller 方法无法重定向到正确的 View ,但显示“我们很抱歉,但出了点问题。”留言
我试过的部署配置
JRuby 1.7.0Gems jruby-rack 1.1.10, 1.0.10 rails 3.2.9, 3.2.0 warbler 1.3.6, 1.3.2Tomcat 7.0.32
here is the access log from tomcat
127.0.0.1 - - [20/Nov/2012:13:56:38 +0800] "GET /demo/ HTTP/1.1" 200 5906127.0.0.1 - - [20/Nov/2012:13:56:49 +0800] "GET /demo/assets/rails.png HTTP/1.1" 404 728127.0.0.1 - - [20/Nov/2012:14:01:21 +0800] "GET /demo/order/add HTTP/1.1" 500 643
here is the log form tomcat
2012/11/20 13:56:18 org.apache.catalina.core.ApplicationContext log 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 log INFO: using : runtime pool with acquire timeout of 10.0 seconds 2012/11/20 13:56:19 org.apache.catalina.core.ApplicationContext log ContextListener: contextInitialized() 2012/11/20 13:56:19 org.apache.catalina.core.ApplicationContext log SessionListener: contextInitialized() 2012/11/20 13:56:19 org.apache.catalina.core.ApplicationContext log ContextListener: attributeAdded('org.apache.jasper.compiler.TldLocationsCache', 'org.apache.jasper.compiler.TldLocationsCache@1858aa0') 2012/11/20 01:56:38 org.apache.catalina.core.ApplicationContext log INFO: pool was empty - getting new application instance 2012/11/20 01:56:47 org.apache.catalina.core.ApplicationContext log Started GET "/demo/assets/rails.png" for 127.0.0.1 at 2012-11-20 13:56:47 +0800 2012/11/20 01:56:47 org.apache.catalina.core.ApplicationContext log Connecting to database specified by database.yml 2012/11/20 01:56:49 org.apache.catalina.core.ApplicationContext log ActionController::RoutingError (No route matches [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' 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 log Started GET "/demo/order/add" for 127.0.0.1 at 2012-11-20 14:01:21 +0800 2012/11/20 14:01:21 org.apache.catalina.core.ApplicationContext log Processing by OrderController#add as HTML 2012/11/20 14:01:21 org.apache.catalina.core.ApplicationContext log Rendered order/add.html.erb within layouts/application (16.0ms) 2012/11/20 14:01:21 org.apache.catalina.core.ApplicationContext log Completed 500 Internal Server Error in 78ms
It's seem that the routing problem is occur, is it the problem when I deploy the rails application other than the ROOT location?
I have research the similar topic of this, I have try some solution, such asadding the below command at production.rb, but no help.
config.action_controller.relative_url_root = "/demo"
感谢您的解决方案
最佳答案
你有没有在鸣叫之前预编译你的 Assets ?
在运行warble
之前需要先运行rake assets:precompile
生成静态内容
关于ruby-on-rails - windows平台下部署jruby项目到tomcat,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13467624/
在 tomcat 内的 jruby/rack 中使用 jruby 时,如何/在哪里为 jruby 设置 --fast 模式? 此 --fast 模式在此页面中进行了说明 jruby performan
任何教程或博客都可以从 JRuby on Rails 开始 哪个指导我安装和小型 JRuby on Rails 应用程序? 我已经浏览了本演练和教程(https://github.com/jruby/
无法使用 jruby 启动 rails5,出现以下错误。 gavinyap@gavin-ubuntu ~/Development/rails5app rails s DEPRECATION W
我制作了一个 NSIS 脚本来为 Rails 应用程序创建安装程序。该应用程序使用 JRuby 和 Java。 在安装程序的第一部分中,我设置了环境变量:我将 jruby\bin 添加到 PATH 并
当我的 jruby 程序意外启动并向我提供堆栈跟踪时,这几乎是不可理解的。它充满了显然来自内部解释器的行,这让我很难弄清楚我的实际程序的实际调用堆栈是什么。 类似的东西(只是摘录): from
如何/在何处为在 jruby-rack/tomcat 中运行的 jruby 设置 --profile.api 选项? 此选项记录在如何分析代码块中 here 最佳答案 使用 JRUBY_OPTS 将无
我无法让 jruby 在没有 hack 的情况下使用 Rails 4: 在 railties/lib/rails/engine.rb 中,我必须用 const_get 初始化 Railties,否则
我需要将我的 JRuby 应用程序编译成一个独立的 JAR 文件。我怎样才能做到这一点? 最佳答案 Warbler 1.3.0 或更新版本也可用于制作可执行 JAR 文件。 快速说明。确保您在此处使用
我正在尝试将 Rails 应用程序转换为 jruby on Rails。目前,jruby script/delayed_job run给出: /usr/lib/jruby/lib/ruby/gems/
我通过在 config/application.rb 中添加了一些外部 jar 到我的 CLASSPATH : require 'java' $CLASSPATH << "#{File.dirname
目前在 Jruby 中编写类似的 java 类时遇到问题。 示例: 在 Java 中: public class Client extends ClientConnection { //do s
jruby 1.7.23 (1.9.3p551) 2015-11-24 f496dd5 在 Java HotSpot(TM) 64 位服务器 VM 1.7.0_79-b15 +jit [Windows
我正在尝试通过最新版本的 Jruby (1.5.1)、Ruby 1.8.7 和 Java 1.6.0_06 执行一些自定义 Java 代码。我已经尝试了类文件并将其放入 jar 方法中。当我尝试 re
文档似乎表明,为了将 Java 类导入到 JRuby 中,它们必须位于 JAR 文件中: “为了使用 JRuby 中的 jar 文件中的资源,jar 文件必须位于类路径上,或者您可以使用 requir
我在 Windows/JRuby 上使用 watir-webdriver。我的开发一直使用 Firefox。 Watir::Browser.new :firefox 对于部署,我需要一个 headle
我正在使用 JRuby 编写 Java 脚本。通过使用 JRebel,我可以自动将更改的 Java 类重新加载到 JRuby JVM 中,而无需重新启动。当我添加一个新的 Java 方法时,JRebe
我试图在 JRuby 中传递一个二进制字符串作为 byte[]通过一些Java库并再次进入JRuby,我想将其转换回字符串,但我无法弄清楚如何在不弄乱字符串的情况下进行操作。 具体来说,我将 Ruby
在Java中运行Ruby脚本时,我们使用ScriptEngine jruby = new ScriptEngineManager().getEngineByName("jruby");,如果只需要调用
当前的 Trinidad gem 依赖于 jruby-rack 1.1.0,它在我的每一项 Assets 的开发日志中显示了一些错误 /Users/bijan/.rvm/gems/jruby-1.7.
环境 JRuby 版本:jruby 9.0.0.0 (2.2.2) 2015-07-21 e10ec96 Java HotSpot(TM) 64 位服务器 VM 25.65-b01,位于 1.8.0_
我是一名优秀的程序员,十分优秀!