Java 如果没有提供范围,为什么Glassfish不会启动失败,而Tomcat会启动呢?

Java 如果没有提供范围,为什么Glassfish不会启动失败,而Tomcat会启动呢?,java,maven,jakarta-ee,tomcat,glassfish,Java,Maven,Jakarta Ee,Tomcat,Glassfish,我有一个非常简单的JavaWeb应用程序,包含2个jsp文件(索引和测试)。部署描述符应该提供一些线索: <web-app... usual stuff here...> <servlet> <servlet-name>BeerServlet</servlet-name> <servlet-class>com.tugay.example.BeerServlet</servlet-class

我有一个非常简单的JavaWeb应用程序,包含2个jsp文件(索引和测试)。部署描述符应该提供一些线索:

<web-app... usual stuff here...>

    <servlet>
        <servlet-name>BeerServlet</servlet-name>
        <servlet-class>com.tugay.example.BeerServlet</servlet-class>

    </servlet>

    <servlet-mapping>
        <servlet-name>BeerServlet</servlet-name>
        <url-pattern>/tugay</url-pattern>
    </servlet-mapping>

</web-app>

啤酒瓶
com.tugay.example.BeerServlet
啤酒瓶
/图盖
该项目由maven-webapp原型创建,pom中只有一个依赖项:

    <dependency>
        <groupId>javax</groupId>
        <artifactId>javaee-api</artifactId>
        <version>6.0</version>
        <scope>provided</scope>
    </dependency>

爪哇
JavaEEAPI
6
假如
我在IntelliJ中有两个运行配置,一个用于Tomcat7.0,一个用于Glassfish 3.1.2.2

当pom如上所述时,应用程序可以部署到两台服务器。但当我删除:

<scope>provided</scope>
已提供
部署在Tomcat中失败,但在Glassfish中仍然成功。为什么会这样

这来自Tomcat日志文件:

严重:配置类的应用程序侦听器时出错 org.apache.catalina.deploy。ApplicationListener@49f8d077 java.lang.ClassNotFoundException: com.sun.faces.config.ConfigureListener位于 org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1714) 在 org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1559) 在 org.apache.catalina.core.DefaultInstanceManager.loadClass(DefaultInstanceManager.java:527) 在 org.apache.catalina.core.DefaultInstanceManager.loadClassMaybePrivileged(DefaultInstanceManager.java:509) 在 org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:137) 在 org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4854) 在 org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5434) 在 org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) 在 org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:901) 在 org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:877) 在 org.apache.catalina.core.StandardHost.addChild(StandardHost.java:633) 在 org.apache.catalina.startup.HostConfig.manageApp(HostConfig.java:1551) 位于的sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法) invoke(NativeMethodAccessorImpl.java:39) 在 reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 位于java.lang.reflect.Method.invoke(Method.java:597) org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:301) 在 com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(DefaultMBeanServerInterceptor.java:836) 在 com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(JmxMBeanServer.java:762) 在 org.apache.catalina.mbeans.MBeanFactory.createStandardContext(MBeanFactory.java:622) 在 org.apache.catalina.mbeans.MBeanFactory.createStandardContext(MBeanFactory.java:569) 位于的sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法) invoke(NativeMethodAccessorImpl.java:39) 在 reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 位于java.lang.reflect.Method.invoke(Method.java:597) org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:301) 在 com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(DefaultMBeanServerInterceptor.java:836) 在 com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(JmxMBeanServer.java:762) 在 javax.management.remote.rmi.RMIConnectionImpl.doOperation(RMIConnectionImpl.java:1454) 在 javax.management.remote.rmi.RMIConnectionImpl.access$300(RMIConnectionImpl.java:74) 在 RMIConnectionImpl$PrivilegedOperation.run(RMIConnectionImpl.java:1295) 在 RMIConnectionImpl.doPrivilegeOperation(RMIConnectionImpl.java:1387) 在 management.remote.rmi.RMIConnectionImpl.invoke(RMIConnectionImpl.java:818) 位于的sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法) invoke(NativeMethodAccessorImpl.java:39) 在 reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 位于java.lang.reflect.Method.invoke(Method.java:597) UnicastServerRef.dispatch(UnicastServerRef.java:303) 在sun.rmi.transport.transport$1.run(transport.java:159)at java.security.AccessController.doPrivileged(本机方法)位于 sun.rmi.transport.transport.serviceCall(transport.java:155)位于 sun.rmi.transport.tcp.tcptTransport.handleMessages(tcptTransport.java:535) 在 tcpttransport$ConnectionHandler.run0(tcpttransport.java:790) 在 tcpttransport$ConnectionHandler.run(tcpttransport.java:649) 在 java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:895) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:918) 在java.lang.Thread.run(Thread.java:662)2013年10月20日凌晨1:03:08 org.apache.catalina.core.StandardContext listenerStart严重:跳过 由于以前的错误而安装应用程序侦听器

provided
在maven中用于告知此库(JavaEEAPI)将由服务器提供。当您省略时,默认值为
compile
意味着在编译期间可以使用所需的JAR,并将其与WAR文件打包在
lib
文件夹中<代码>javaee api包包含javax.servlet、javax.servlet.http。。etc,这也是Tomcat提供的。 所以当您省略作用域时,jar被打包在WAR文件中,但这个jar也是由tomcat提供的,所以存在jar冲突。
Glassfish能够解决此问题。

Glassfish使用OSGi技术制造。OSGi旨在解决同一个jar的多个版本的问题。从技术上讲,如果我从tomcats lib文件夹中删除这些类,它应该可以工作,对吧?是的。只需从lib中删除