java - WAR 部署上的 Groovy Grails 工具套件 NoClassDefFoundError

标签 java tomcat grails groovy

使用:GG 版本 2.2.4;和 Groovy/Grails 工具套件版本:3.3.0.RELEASE

问题是:如何将特定的 Grails JAR 放入使用 GGTS 构建的 WAR 中?

作为附带问题,为什么 WAR 不将 JAR 打包到其中?为什么“grails run-app”工作正常,但部署 WAR(在开发或生产中)却失败了?

这是背景:

当我在我的 Windows 7 开发计算机上本地运行“grails run-war”时,它失败了:

2013-10-16 11:36:05,371 [localhost-startStop-1] ERROR context.ContextLoader  - Context initialization failed
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'grailsApplication' defined in ServletContext resource [/WEB-INF/applicationContext.xml]: Invocation of init method failed; nested exception is java.lang.NoClassDefFoundError: grails/test/mixin/domain/DomainClassUnitTestMixin
    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334)
    at java.util.concurrent.FutureTask.run(FutureTask.java:166)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
    at java.lang.Thread.run(Thread.java:724)
**Caused by: java.lang.NoClassDefFoundError: grails/test/mixin/domain/DomainClassUnitTestMixin**

当我运行“grails war”然后将 Production WAR 部署到我服务器上的 Tomcat 6 时,我在 catalina.out 中遇到类似的部署错误:

INFO   | jvm 1    | 2013/10/16 17:03:47 | Oct 16, 2013 5:03:47 PM org.apache.catalina.core.ApplicationContext log
INFO   | jvm 1    | 2013/10/16 17:03:47 | INFO: HTMLManager: start: Starting web application at '/TSWeb-0.1'
INFO   | jvm 1    | 2013/10/16 17:03:48 | Oct 16, 2013 5:03:48 PM org.apache.catalina.core.ApplicationContext log
INFO   | jvm 1    | 2013/10/16 17:03:48 | INFO: Initializing Spring root WebApplicationContext
INFO   | jvm 1    | 2013/10/16 17:03:49 | 2013-10-16 17:03:49,388 [TP-Processor2] ERROR context.ContextLoader  - Context initialization failed
INFO   | jvm 1    | 2013/10/16 17:03:49 | org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'grailsApplication' defined in ServletContext resource [/WEB-INF/applicationContext.xml]: Invocation of init method failed; nested exception is java.lang.NoClassDefFoundError: grails/test/mixin/support/GrailsUnitTestMixin
INFO   | jvm 1    | 2013/10/16 17:03:49 |   at org.apache.jk.server.JkCoyoteHandler.invoke(JkCoyoteHandler.java:190)
INFO   | jvm 1    | 2013/10/16 17:03:49 |   at org.apache.jk.common.HandlerRequest.invoke(HandlerRequest.java:311)
INFO   | jvm 1    | 2013/10/16 17:03:49 |   at org.apache.jk.common.ChannelSocket.invoke(ChannelSocket.java:776)
INFO   | jvm 1    | 2013/10/16 17:03:49 |   at org.apache.jk.common.ChannelSocket.processConnection(ChannelSocket.java:705)
INFO   | jvm 1    | 2013/10/16 17:03:49 |   at org.apache.jk.common.ChannelSocket$SocketConnection.runIt(ChannelSocket.java:898)
INFO   | jvm 1    | 2013/10/16 17:03:49 |   at java.lang.Thread.run(Thread.java:724)
INFO   | jvm 1    | 2013/10/16 17:03:49 | **Caused by: java.lang.NoClassDefFoundError: grails/test/mixin/support/GrailsUnitTestMixin**
INFO   | jvm 1    | 2013/10/16 17:03:49 |   at java.lang.Class.forName(Class.java:270)

我可以在 WAR 内部进行探索,发现 WEB-INF/lib/不包含上述两个类所在的 JAR (grails-plugin-testing-2.2.4.jar)。

我试过

grails.war.dependencies = [
    "grails-plugin-testing-2.2.4.jar"
    ]

进入 config.groovy 并且这没有用。 WAR 仍然不包含那个 JAR,我得到了同样的错误。

所以,我只是将 grails-plugin-testing-2.2.4.jar 放入服务器上的 WEB-INF/lib 文件夹中,然后重新部署并验证上面的错误消失了,但现在我在服务器:

INFO   | jvm 1    | 2013/10/16 18:34:02 | Oct 16, 2013 6:34:02 PM org.apache.catalina.core.ApplicationContext log
INFO   | jvm 1    | 2013/10/16 18:34:02 | INFO: HTMLManager: start: Starting web application at '/TSWeb-0.1'
INFO   | jvm 1    | 2013/10/16 18:34:03 | Oct 16, 2013 6:34:03 PM org.apache.catalina.core.ApplicationContext log
INFO   | jvm 1    | 2013/10/16 18:34:03 | INFO: Initializing Spring root WebApplicationContext
INFO   | jvm 1    | 2013/10/16 18:34:07 | 2013-10-16 18:34:07,011 [TP-Processor12] ERROR context.ContextLoader  - Context initialization failed
INFO   | jvm 1    | 2013/10/16 18:34:07 | org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'pluginManager' defined in ServletContext resource [/WEB-INF/applicationContext.xml]: Invocation of init method failed; nested exception is java.lang.RuntimeException: Unable to locate constructor with Class parameter for class org.codehaus.groovy.grails.commons.DefaultGrailsBootstrapClass
INFO   | jvm 1    | 2013/10/16 18:34:07 |   at org.apache.jk.server.JkCoyoteHandler.invoke(JkCoyoteHandler.java:190)
INFO   | jvm 1    | 2013/10/16 18:34:07 |   at org.apache.jk.common.HandlerRequest.invoke(HandlerRequest.java:311)
INFO   | jvm 1    | 2013/10/16 18:34:07 |   at org.apache.jk.common.ChannelSocket.invoke(ChannelSocket.java:776)
INFO   | jvm 1    | 2013/10/16 18:34:07 |   at org.apache.jk.common.ChannelSocket.processConnection(ChannelSocket.java:705)
INFO   | jvm 1    | 2013/10/16 18:34:07 |   at org.apache.jk.common.ChannelSocket$SocketConnection.runIt(ChannelSocket.java:898)
INFO   | jvm 1    | 2013/10/16 18:34:07 |   at java.lang.Thread.run(Thread.java:724)
INFO   | jvm 1    | 2013/10/16 18:34:07 | Caused by: java.lang.RuntimeException: Unable to locate constructor with Class parameter for class org.codehaus.groovy.grails.commons.DefaultGrailsBootstrapClass
INFO   | jvm 1    | 2013/10/16 18:34:07 |   ... 6 more
INFO   | jvm 1    | 2013/10/16 18:34:07 | Caused by: java.lang.reflect.InvocationTargetException
INFO   | jvm 1    | 2013/10/16 18:34:07 |   ... 6 more
INFO   | jvm 1    | 2013/10/16 18:34:07 | Caused by: java.lang.NoClassDefFoundError: grails/test/GrailsMock
INFO   | jvm 1    | 2013/10/16 18:34:07 |   at java.lang.Class.privateGetDeclaredMethods(Class.java:2521)
INFO   | jvm 1    | 2013/10/16 18:34:07 |   at java.lang.Class.getDeclaredMethods(Class.java:1845)
INFO   | jvm 1    | 2013/10/16 18:34:07 |   ... 6 more
INFO   | jvm 1    | 2013/10/16 18:34:07 | Caused by: java.lang.ClassNotFoundException: grails.test.GrailsMock
INFO   | jvm 1    | 2013/10/16 18:34:07 |   ... 8 more

我将调查第二个错误并在另一个问题中询问它并在此处引用它。 [更新:如果我也将 grails-test-2.2.4.jar 放入服务器上的 WEB-INF/lib 中,这个错误就会消失。然后,WAR部署并成功运行。]

为了使这个问题/答案保持在一个主题上,我如何将这 2 个 JAR 放入 WAR 中?

但是,当然,也许有一个解决方案可以解决这两个问题(嘿嘿嘿 - 不太可能但值得一提!)例如,我不知道为什么 grails-plugin-testing-2.2.4 .jar 被使用。也许我需要更改某个设置才能“消失”。

谢谢!

最佳答案

好的 - 想通了 - 足以使它工作....

[仍然不明白为什么 GG 不自己捡起那些 JAR。]

为了找出哪些 JAR 文件包含在 WAR 部署期间报告丢失的类,我只是在包含安装了 Groovy/Grails v2.2.4 (C:\grails-2.2) 的 grails JAR 的 dist 文件夹中进行了查找.4\距离)。我使用 7zip 来浏览 JAR。由于这两个类中都有“测试”一词,我首先在名称中带有“测试”的 JARS 中查找并轻松找到了它们。这就是我如何计算出我在上面列出的包含这些类的问题中的两个 JAR 文件的方法。

将它们放在服务器上的 WEB-INF/lib 文件夹中,然后成功启动/部署项目确认将它们放入 WAR 中可以解决问题。

为了让它们进入项目并因此在创建 WAR 时,我这样做了......

1) run “grails clean” on the project in question
2) close the project (and all others)
3) exit g&g tool suite
4) drag the jar file to your “PROJECTNAME/lib” directory for your project using Windows Explorer.
5) start g&g tool suite
6) open the project
7) right-click on the Project Name and choose Groovy Tools -> Refresh Dependencies

现在,也许您不必跳过所有这些步骤就可以让刷新依赖项正常工作,但这就是我所做的。如果我只做#7,而不先做其他事情,那么它在这个版本的 GGTS 上不起作用。现在,WAR 生成并正确部署在服务器上。

关于java - WAR 部署上的 Groovy Grails 工具套件 NoClassDefFoundError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19410995/

相关文章:

tomcat - Cloudfoundry,默认协议(protocol)

azure - 使用 terraform 的 Azure VM 上的 Tomcat?

javascript - 使用 Grails Asset-Pipeline 将 JavaScript 置于底部

ruby-on-rails - Rails 没有 ActiveRecord 的好处,Grails 没有 GORM

grails - Grails Spring Security-动态加载 “interceptUrlMap”

java - 有什么好的方法可以将多维数组转换为 List<List<T>>?

java - 在枚举结构上循环时重构和删除 case 语句

java - 如何将自定义 java 类导入到我的 Antlr 语法中?

java - 单击selenium中的CSS按钮

tomcat - 为 Tomcat 转换 log4j.properties 文件以使用 Log4j2