[rules-dev] M2 Guvnor Tomcat Deployment Issues and Resolutions
Toni Rikkola
trikkola at redhat.com
Fri Nov 7 12:07:24 EST 2008
Thank you for the solution. I updated the drools-guvnor pom.xml.
I used seam 2.1.0.GA and didn't disable the el-api. But tested with
tomcat and JBoss AS and it works.
Toni
Mark Proctor wrote:
> mellster wrote:
>> FYI, here are a few more hacks I had to make (after checking out the latest
>> from trunk) to get guvnor started on tomcat6 and j2se1.5 on WinXP
>>
>> 1) java.lang.NoClassDefFoundError: org/drools/ObjectFilter
>>
>> It looks like this one moved to the org.drools.runtime package - duplicated
>> the source file into org/drools and rebuilt.
>>
> If you are working with trunk, we are introducing drools-api, which
> has some changes like this. But I shouldn't be breaking api
> compatability, I see now I made a refactoring mistake. I should have
> kept an ObjectFilter in org.drools, that inherited the runtime one,
> fixing this now. Let me know if there any other api changes like this,
> so I can revert them.
>
> Mark
>> 2) javax.jcr.NamespaceException: http://www.jboss.org/drools-repository/1.0
>> is not a registered namespace uri
>>
>> Added the line
>>
>> drools=http\://www.jboss.org/drools-repository/1.0
>>
>> to bin/repository/repository/namespaces/ns_reg
>>
>> 3) jsf not found (if you're running with J2SE instead of J2EE)
>>
>> Added jsf-api and jsf-impl to the pom (runtime scope should do it)
>>
>> '<dependency>
>> <groupId>javax.faces</groupId>
>> <artifactId>jsf-api</artifactId>
>> <version>1.2_02</version>
>> </dependency>
>>
>> <dependency>
>> <groupId>javax.faces</groupId>
>> <artifactId>jsf-impl</artifactId
>> <version>1.2-b19</version>
>> </dependency>
>>
>> cheers
>>
>> Marco
>>
>>
>> dave sinclair wrote:
>>
>>> Just a heads up for everyone out there. I needed to make the following
>>> changes to guvnor's POM in order to get the webapp to work properly on
>>> Tomcat. I would imagine some of these issues would appear on JBoss also
>>> but
>>> have not tried.
>>>
>>> 1. Changed seam from 2.1.0.BETA1 to 2.1.0-SNAPSHOT to prevent classloader
>>> problem
>>>
>>> POM Changes
>>> <dependency>
>>> <groupId>org.jboss.seam</groupId>
>>> <artifactId>jboss-seam-remoting</artifactId>
>>> <version>2.1.0-SNAPSHOT</version>
>>> </dependency>
>>> <dependency>
>>> <groupId>org.jboss.seam</groupId>
>>> <artifactId>jboss-seam</artifactId>
>>> <version>2.1.0-SNAPSHOT</version>
>>> </dependency>
>>>
>>> EXCEPTION without change
>>>
>>> SEVERE: Exception sending context initialized event to listener instance
>>> of
>>> class org.jboss.seam.servlet.SeamListener
>>> java.lang.IllegalStateException: Cannot load
>>> WEB-INF/classes/net/sf/webdav/exceptions/AccessDeniedException.class from
>>> WebappClassLoader
>>> delegate: false
>>> repositories:
>>> /WEB-INF/classes/
>>> ----------> Parent Classloader:
>>> org.apache.catalina.loader.StandardClassLoader at c4fe76
>>> (using getResourceAsStream() returned null)
>>> at
>>> org.jboss.seam.deployment.AbstractDeploymentHandler.getClassFile(AbstractDeploymentHandler.java:41)
>>> at
>>> org.jboss.seam.deployment.ComponentDeploymentHandler.handle(ComponentDeploymentHandler.java:57)
>>> at
>>> org.jboss.seam.deployment.DeploymentStrategy.handle(DeploymentStrategy.java:177)
>>> at
>>> org.jboss.seam.deployment.AbstractScanner.handleItem(AbstractScanner.java:30)
>>> at
>>> org.jboss.seam.deployment.URLScanner.handleDirectory(URLScanner.java:141)
>>> at
>>> org.jboss.seam.deployment.URLScanner.handleDirectory(URLScanner.java:137)
>>> at
>>> org.jboss.seam.deployment.URLScanner.handleDirectory(URLScanner.java:137)
>>> at
>>> org.jboss.seam.deployment.URLScanner.handleDirectory(URLScanner.java:137)
>>> at
>>> org.jboss.seam.deployment.URLScanner.handleDirectory(URLScanner.java:137)
>>> at
>>> org.jboss.seam.deployment.URLScanner.handleDirectory(URLScanner.java:137)
>>> at
>>> org.jboss.seam.deployment.URLScanner.handleDirectory(URLScanner.java:137)
>>> at
>>> org.jboss.seam.deployment.URLScanner.scanDirectories(URLScanner.java:40)
>>> at
>>> org.jboss.seam.deployment.StandardDeploymentStrategy.scan(StandardDeploymentStrategy.java:107)
>>> at
>>> org.jboss.seam.init.Initialization.create(Initialization.java:113)
>>> at
>>> org.jboss.seam.servlet.SeamListener.contextInitialized(SeamListener.java:34)
>>> at
>>> org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3843)
>>> at
>>> org.apache.catalina.core.StandardContext.start(StandardContext.java:4350)
>>> at
>>> org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)
>>> at
>>> org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)
>>> at
>>> org.apache.catalina.core.StandardHost.addChild(StandardHost.java:525)
>>> at
>>> org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:829)
>>> at
>>> org.apache.catalina.startup.HostConfig.deployWARs(HostConfig.java:718)
>>> at
>>> org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:490)
>>> at
>>> org.apache.catalina.startup.HostConfig.start(HostConfig.java:1147)
>>> at
>>> org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:311)
>>> at
>>> org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:117)
>>> at
>>> org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
>>> at
>>> org.apache.catalina.core.StandardHost.start(StandardHost.java:719)
>>> at
>>> org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
>>> at
>>> org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)
>>> at
>>> org.apache.catalina.core.StandardService.start(StandardService.java:516)
>>> at
>>> org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
>>> at org.apache.catalina.startup.Catalina.start(Catalina.java:578)
>>> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
>>> at
>>> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
>>> at
>>> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
>>> at java.lang.reflect.Method.invoke(Method.java:597)
>>> at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288)
>>> at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)
>>>
>>> 2. Added javax.persistence to prevent ClassNotFoundException
>>>
>>> POM Changes
>>>
>>> <dependency>
>>> <groupId>javax.persistence</groupId>
>>> <artifactId>persistence-api</artifactId>
>>> <version>1.0</version>
>>> </dependency>
>>>
>>> EXCEPTION without change
>>>
>>> SEVERE: Exception sending context initialized event to listener instance
>>> of
>>> class org.jboss.seam.servlet.SeamListener
>>> java.lang.RuntimeException: Could not create Component:
>>> org.jboss.seam.core.init
>>> at
>>> org.jboss.seam.init.Initialization.addComponent(Initialization.java:1068)
>>> at
>>> org.jboss.seam.init.Initialization.init(Initialization.java:614)
>>> at
>>> org.jboss.seam.servlet.SeamListener.contextInitialized(SeamListener.java:34)
>>> at
>>> org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3843)
>>> at
>>> org.apache.catalina.core.StandardContext.start(StandardContext.java:4350)
>>> at
>>> org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)
>>> at
>>> org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)
>>> at
>>> org.apache.catalina.core.StandardHost.addChild(StandardHost.java:525)
>>> at
>>> org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:829)
>>> at
>>> org.apache.catalina.startup.HostConfig.deployWARs(HostConfig.java:718)
>>> at
>>> org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:490)
>>> at
>>> org.apache.catalina.startup.HostConfig.start(HostConfig.java:1147)
>>> at
>>> org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:311)
>>> at
>>> org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:117)
>>> at
>>> org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
>>> at
>>> org.apache.catalina.core.StandardHost.start(StandardHost.java:719)
>>> at
>>> org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
>>> at
>>> org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)
>>> at
>>> org.apache.catalina.core.StandardService.start(StandardService.java:516)
>>> at
>>> org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
>>> at org.apache.catalina.startup.Catalina.start(Catalina.java:578)
>>> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
>>> at
>>> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
>>> at
>>> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
>>> at java.lang.reflect.Method.invoke(Method.java:597)
>>> at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288)
>>> at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)
>>> Caused by: java.lang.NoClassDefFoundError: javax/persistence/Entity
>>> at org.jboss.seam.Seam.getComponentType(Seam.java:109)
>>> at org.jboss.seam.Component.<init>(Component.java:210)
>>> at org.jboss.seam.Component.<init>(Component.java:199)
>>> at
>>> org.jboss.seam.init.Initialization.addComponent(Initialization.java:1052)
>>> ... 26 more
>>> Caused by: java.lang.ClassNotFoundException: javax.persistence.Entity
>>> at
>>> org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1360)
>>> at
>>> org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1206)
>>> at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:319)
>>> ... 30 more
>>>
>>> 3. Added hibernate-validator to prevent ClassNotFoundException
>>>
>>> POM Changes
>>>
>>> <dependency>
>>> <groupId>org.hibernate</groupId>
>>> <artifactId>hibernate-validator</artifactId>
>>> <version>3.0.0.GA</version>
>>> </dependency>
>>>
>>> EXCEPTION without change
>>>
>>> SEVERE: Exception sending context initialized event to listener instance
>>> of
>>> class org.jboss.seam.servlet.SeamListener
>>> java.lang.RuntimeException: Could not create Component:
>>> org.jboss.seam.international.statusMessages
>>> at
>>> org.jboss.seam.init.Initialization.addComponent(Initialization.java:1068)
>>> at
>>> org.jboss.seam.init.Initialization.installComponents(Initialization.java:984)
>>> at
>>> org.jboss.seam.init.Initialization.init(Initialization.java:646)
>>> at
>>> org.jboss.seam.servlet.SeamListener.contextInitialized(SeamListener.java:34)
>>> at
>>> org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3843)
>>> at
>>> org.apache.catalina.core.StandardContext.start(StandardContext.java:4350)
>>> at
>>> org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)
>>> at
>>> org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)
>>> at
>>> org.apache.catalina.core.StandardHost.addChild(StandardHost.java:525)
>>> at
>>> org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:829)
>>> at
>>> org.apache.catalina.startup.HostConfig.deployWARs(HostConfig.java:718)
>>> at
>>> org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:490)
>>> at
>>> org.apache.catalina.startup.HostConfig.start(HostConfig.java:1147)
>>> at
>>> org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:311)
>>> at
>>> org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:117)
>>> at
>>> org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
>>> at
>>> org.apache.catalina.core.StandardHost.start(StandardHost.java:719)
>>> at
>>> org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
>>> at
>>> org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)
>>> at
>>> org.apache.catalina.core.StandardService.start(StandardService.java:516)
>>> at
>>> org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
>>> at org.apache.catalina.startup.Catalina.start(Catalina.java:578)
>>> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
>>> at
>>> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
>>> at
>>> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
>>> at java.lang.reflect.Method.invoke(Method.java:597)
>>> at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288)
>>> at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)
>>> Caused by: java.lang.NoClassDefFoundError:
>>> [Lorg/hibernate/validator/InvalidValue;
>>> at java.lang.Class.getDeclaredMethods0(Native Method)
>>> at java.lang.Class.privateGetDeclaredMethods(Class.java:2427)
>>> at java.lang.Class.privateGetPublicMethods(Class.java:2547)
>>> at java.lang.Class.privateGetPublicMethods(Class.java:2563)
>>> at java.lang.Class.getMethods(Class.java:1410)
>>> at org.jboss.seam.Component.hasAnnotation(Component.java:1078)
>>> at org.jboss.seam.Component.<init>(Component.java:212)
>>> at org.jboss.seam.Component.<init>(Component.java:199)
>>> at
>>> org.jboss.seam.init.Initialization.addComponent(Initialization.java:1052)
>>> ... 27 more
>>> Caused by: java.lang.ClassNotFoundException:
>>> org.hibernate.validator.InvalidValue
>>> at
>>> org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1360)
>>> at
>>> org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1206)
>>> at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:319)
>>> ... 36 more
>>>
>>> 4. Seam's version of the Java Expression Language was clashing with
>>> Tomcat's
>>>
>>> POM Changes
>>>
>>> - exclude from seam
>>> <dependency>
>>> <groupId>org.jboss.seam</groupId>
>>> <artifactId>jboss-seam</artifactId>
>>> <version>2.1.0-SNAPSHOT</version>
>>> <exclusions>
>>> <exclusion>
>>> <groupId>javax.el</groupId>
>>> <artifactId>el-api</artifactId>
>>> </exclusion>
>>> </exclusions>
>>> </dependency>
>>> - comment out from POM
>>> <!--<dependency>-->
>>> <!--<groupId>javax.el</groupId>-->
>>> <!--<artifactId>el-api</artifactId>-->
>>> <!--<version>1.2</version>-->
>>> <!--<scope>runtime</scope>-->
>>> <!--</dependency>-->
>>>
>>>
>>> Exception without change
>>>
>>> java.lang.LinkageError: loader constraint violation: when resolving
>>> interface method
>>> "javax.servlet.jsp.JspApplicationContext.getExpressionFactory()Lj
>>> avax/el/ExpressionFactory;" the class loader (instance of
>>> org/apache/jasper/servlet/JasperLoader) of the current class,
>>> org/apache/jsp/index_jsp, and
>>> the class loader (instance of
>>> org/apache/catalina/loader/StandardClassLoader) for resolved class,
>>> javax/servlet/jsp/JspApplicationContext, have differ
>>> ent Class objects for the type javax/el/ExpressionFactory used in the
>>> signature
>>> at org.apache.jsp.index_jsp._jspInit(index_jsp.java:22)
>>> at org.apache.jasper.runtime.HttpJspBase.init(HttpJspBase.java:52)
>>> at
>>> org.apache.jasper.servlet.JspServletWrapper.getServlet(JspServletWrapper.java:159)
>>> at
>>> org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:329)
>>> at
>>> org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:337)
>>> at
>>> org.apache.jasper.servlet.JspServlet.service(JspServlet.java:266)
>>> at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
>>> at
>>> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
>>> at
>>> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
>>> at
>>> org.jboss.seam.web.ContextFilter$1.process(ContextFilter.java:42)
>>> at
>>> org.jboss.seam.servlet.ContextualHttpServletRequest.run(ContextualHttpServletRequest.java:53)
>>> at
>>> org.jboss.seam.web.ContextFilter.doFilter(ContextFilter.java:37)
>>> at
>>> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
>>> at
>>> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
>>> at
>>> org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
>>> at
>>> org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
>>> at
>>> org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
>>> at
>>> org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
>>> at
>>> org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
>>> at
>>> org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:286)
>>> at
>>> org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)
>>> at
>>> org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
>>> at
>>> org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
>>> at java.lang.Thread.run(Thread.java:619)
>>>
>>> let me know if we should use different versions then the ones I have
>>> listed.
>>>
>>> thanks
>>>
>>> dave sinclair
>>>
>>> _______________________________________________
>>> rules-dev mailing list
>>> rules-dev at lists.jboss.org
>>> https://lists.jboss.org/mailman/listinfo/rules-dev
>>>
>>>
>>>
>>
>>
>
> ------------------------------------------------------------------------
>
> _______________________________________________
> rules-dev mailing list
> rules-dev at lists.jboss.org
> https://lists.jboss.org/mailman/listinfo/rules-dev
>
More information about the rules-dev
mailing list