1

2 つの jsp ファイル ( index と test ) を持つ非常に単純な Java Web アプリケーションがあります。デプロイメント記述子は、いくつかの手がかりを与えるはずです:

<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>

このプロジェクトは maven -webapp archetype によって作成され、pom には依存関係が 1 つだけあります。

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

IntelliJ には、Tomcat 7.0 用と Glassfish 3.1.2.2 用の 2 つの実行構成があります。

pom が上記の場合、アプリは両方のサーバーに正常にデプロイされます。しかし、私が削除すると:

<scope>provided</scope>

Tomcat ではデプロイが失敗しますが、Glassfish では引き続き成功します。どうしてこれなの?

これは、Tomcat ログ ファイルからのものです。

SEVERE: クラス org.apache.catalina.deploy.ApplicationListener@49f8d077 java.lang.ClassNotFoundException のアプリケーション リスナーの構成エラー: org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java での com.sun.faces.config.ConfigureListener :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.org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) の startInternal(StandardContext.java:5434) org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:901) の org.apache org.apache.catalina.core.StandardHost.addChild(StandardHost.java:633) の .catalina.core.ContainerBase.addChild(ContainerBase.java:877) org.apache.catalina.startup.HostConfig.manageApp(HostConfig.java) の:1551) で sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) で sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) で sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) で java.lang. com.sun.jmx の org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:301) のreflect.Method.invoke(Method.java:597)。org.apache.catalina.mbeans.MBeanFactory.createStandardContext(MBeanFactory.java:622) の com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(JmxMBeanServer.java:762) でのinterceptor.DefaultMBeanServerInterceptor.invoke(DefaultMBeanServerInterceptor.java:836) org.apache.catalina.mbeans.MBeanFactory.createStandardContext(MBeanFactory.java:569) で sun.reflect.NativeMethodAccessorImpl.invoke0(ネイティブ メソッド) で sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) で sun.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) at javax.management.remote.rmi.RMIConnectionImpl$PrivilegedOperation.run(RMIConnectionImpl.java:1295) at javax.management.remote.rmi.RMIConnectionImpl.doPrivilegedOperation(RMIConnectionImpl.java:1387) javax.management.remote.rmi.RMIConnectionImpl.invoke(RMIConnectionImpl.java:818) で sun.reflect.NativeMethodAccessorImpl.invoke0(ネイティブ メソッド) で sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) で sun.reflect java.lang.reflect.Method の .DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)。java.security.AccessController で、sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:303) で呼び出し (Method.java:597)。 doPrivileged(Native Method) の sun.rmi.transport.Transport.serviceCall(Transport.java:155) の sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:535) の sun.rmi.transport.tcp. java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java: 895) 2013 年 10 月 20 日 1:03:08 AM org.apache. catalina.core.StandardContext listenerStart SEVERE: 以前のエラーのため、アプリケーション リスナーのインストールをスキップしました

4

1 に答える 1