0

I'm experiencing issues while configuring a servlet in web.xml of my application (Tomcat9, Java JAX-RS). After a lot of trial and error I managed to reduce the problem to the observation that having init-param tag present in web.xml somehow causes the services - url-pattern in servlet-mapping - to be unavailable (getting 404 while trying to access them).

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5"
         xmlns="http://java.sun.com/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
    http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
  <display-name>Test</display-name>
  <servlet>
    <display-name>JAX-RS REST Servlet</display-name>
    <servlet-name>JAX-RS REST Servlet</servlet-name>
    <servlet-class>
      org.glassfish.jersey.servlet.ServletContainer
    </servlet-class>
    <init-param>
      <param-name>parname</param-name>
      <param-value>parval</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>JAX-RS REST Servlet</servlet-name>
    <url-pattern>/services/*</url-pattern>
  </servlet-mapping>
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
</web-app>

If take the above init-param out of the file I'm able to access http://localhost:8081/app/services/whatever otherwise getting 404 as if servlet-mapping got ineffective.

I was analyzing the catalina logs having deployed both variants of the application and there is no difference except for the timestamp. I think the java.lang.ClassCastException is irrelevant... or is it? :)

catalina with the init-param:

05-Apr-2023 11:04:47.923 INFO [Catalina-utility-1] org.apache.catalina.startup.HostConfig.undeploy Undeploying context [/testDevOps]
05-Apr-2023 11:04:47.933 WARNING [Catalina-utility-1] org.apache.catalina.loader.WebappClassLoaderBase.clearReferencesObjectStreamClassCaches Failed to clear soft references from ObjectStreamClass$Caches for web application [testDevOps]
    java.lang.ClassCastException: class java.io.ObjectStreamClass$Caches$1 cannot be cast to class java.util.Map (java.io.ObjectStreamClass$Caches$1 and java.util.Map are in module java.base of loader 'bootstrap')
      at org.apache.catalina.loader.WebappClassLoaderBase.clearCache(WebappClassLoaderBase.java:2325)
      at org.apache.catalina.loader.WebappClassLoaderBase.clearReferencesObjectStreamClassCaches(WebappClassLoaderBase.java:2300)
      at org.apache.catalina.loader.WebappClassLoaderBase.clearReferences(WebappClassLoaderBase.java:1669)
      at org.apache.catalina.loader.WebappClassLoaderBase.stop(WebappClassLoaderBase.java:1597)
      at org.apache.catalina.loader.WebappLoader.stopInternal(WebappLoader.java:463)
      at org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:257)
      at org.apache.catalina.core.StandardContext.stopInternal(StandardContext.java:5515)
      at org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:257)
      at org.apache.catalina.core.ContainerBase.removeChild(ContainerBase.java:814)
      at org.apache.catalina.startup.HostConfig.undeploy(HostConfig.java:1466)
      at org.apache.catalina.startup.HostConfig.checkResources(HostConfig.java:1391)
      at org.apache.catalina.startup.HostConfig.check(HostConfig.java:1654)
      at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:315)
      at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:123)
      at org.apache.catalina.core.ContainerBase.backgroundProcess(ContainerBase.java:1162)
      at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.processChildren(ContainerBase.java:1365)
      at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.processChildren(ContainerBase.java:1369)
      at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.run(ContainerBase.java:1347)
      at java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515)
      at java.base/java.util.concurrent.FutureTask.runAndReset(FutureTask.java:305)
      at java.base/java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:305)
      at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
      at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
      at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
      at java.base/java.lang.Thread.run(Thread.java:829)
05-Apr-2023 11:04:51.828 INFO [http-nio-8081-exec-7] org.apache.catalina.startup.HostConfig.deployWAR Deploying web application archive [/var/lib/tomcat9/webapps/testDevOps.war]
05-Apr-2023 11:04:52.340 INFO [http-nio-8081-exec-7] org.apache.jasper.servlet.TldScanner.scanJars At least one JAR was scanned for TLDs yet contained no TLDs. Enable debug logging for this logger for a complete list of JARs that were scanned but no TLDs were found in them. Skipping unneeded JARs during scanning can improve startup time and JSP compilation time.
05-Apr-2023 11:04:52.439 WARNING [http-nio-8081-exec-7] org.glassfish.jersey.message.internal.MessagingBinders$EnabledProvidersBinder.bindToBinder A class javax.activation.DataSource for a default provider MessageBodyWriter<javax.activation.DataSource> was not found. The provider is not available.
05-Apr-2023 11:04:52.448 WARNING [http-nio-8081-exec-7] org.glassfish.jersey.server.wadl.WadlFeature.configure JAX-B API not found . WADL feature is disabled.
05-Apr-2023 11:04:52.500 INFO [http-nio-8081-exec-7] org.apache.catalina.startup.HostConfig.deployWAR Deployment of web application archive [/var/lib/tomcat9/webapps/testDevOps.war] has finished in [673] ms

catalina without the init-param

05-Apr-2023 11:06:38.449 INFO [Catalina-utility-1] org.apache.catalina.startup.HostConfig.undeploy Undeploying context [/testDevOps]
05-Apr-2023 11:06:38.460 WARNING [Catalina-utility-1] org.apache.catalina.loader.WebappClassLoaderBase.clearReferencesObjectStreamClassCaches Failed to clear soft references from ObjectStreamClass$Caches for web application [testDevOps]
    java.lang.ClassCastException: class java.io.ObjectStreamClass$Caches$1 cannot be cast to class java.util.Map (java.io.ObjectStreamClass$Caches$1 and java.util.Map are in module java.base of loader 'bootstrap')
      at org.apache.catalina.loader.WebappClassLoaderBase.clearCache(WebappClassLoaderBase.java:2325)
      at org.apache.catalina.loader.WebappClassLoaderBase.clearReferencesObjectStreamClassCaches(WebappClassLoaderBase.java:2300)
      at org.apache.catalina.loader.WebappClassLoaderBase.clearReferences(WebappClassLoaderBase.java:1669)
      at org.apache.catalina.loader.WebappClassLoaderBase.stop(WebappClassLoaderBase.java:1597)
      at org.apache.catalina.loader.WebappLoader.stopInternal(WebappLoader.java:463)
      at org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:257)
      at org.apache.catalina.core.StandardContext.stopInternal(StandardContext.java:5515)
      at org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:257)
      at org.apache.catalina.core.ContainerBase.removeChild(ContainerBase.java:814)
      at org.apache.catalina.startup.HostConfig.undeploy(HostConfig.java:1466)
      at org.apache.catalina.startup.HostConfig.checkResources(HostConfig.java:1391)
      at org.apache.catalina.startup.HostConfig.check(HostConfig.java:1654)
      at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:315)
      at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:123)
      at org.apache.catalina.core.ContainerBase.backgroundProcess(ContainerBase.java:1162)
      at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.processChildren(ContainerBase.java:1365)
      at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.processChildren(ContainerBase.java:1369)
      at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.run(ContainerBase.java:1347)
      at java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515)
      at java.base/java.util.concurrent.FutureTask.runAndReset(FutureTask.java:305)
      at java.base/java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:305)
      at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
      at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
      at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
      at java.base/java.lang.Thread.run(Thread.java:829)
05-Apr-2023 11:06:39.945 INFO [http-nio-8081-exec-12] org.apache.catalina.startup.HostConfig.deployWAR Deploying web application archive [/var/lib/tomcat9/webapps/testDevOps.war]
05-Apr-2023 11:06:40.400 INFO [http-nio-8081-exec-12] org.apache.jasper.servlet.TldScanner.scanJars At least one JAR was scanned for TLDs yet contained no TLDs. Enable debug logging for this logger for a complete list of JARs that were scanned but no TLDs were found in them. Skipping unneeded JARs during scanning can improve startup time and JSP compilation time.
05-Apr-2023 11:06:40.506 WARNING [http-nio-8081-exec-12] org.glassfish.jersey.message.internal.MessagingBinders$EnabledProvidersBinder.bindToBinder A class javax.activation.DataSource for a default provider MessageBodyWriter<javax.activation.DataSource> was not found. The provider is not available.
05-Apr-2023 11:06:40.512 WARNING [http-nio-8081-exec-12] org.glassfish.jersey.server.wadl.WadlFeature.configure JAX-B API not found . WADL feature is disabled.
05-Apr-2023 11:06:40.594 INFO [http-nio-8081-exec-12] org.apache.catalina.startup.HostConfig.deployWAR Deployment of web application archive [/var/lib/tomcat9/webapps/testDevOps.war] has finished in [650] ms

Any suggestions for further steps?

Christopher Schultz
  • 20,221
  • 9
  • 60
  • 77
lewap02
  • 1
  • 2
  • The `ClassCastException` is indeed a red herring: it's being thrown during application-stop. Try stopping Tomcat completely, then deleting all logs, then starting it up under each configuration and capturing the logs. – Christopher Schultz Apr 05 '23 at 21:20

1 Answers1

0

Your application WAR file is called testDevOps.war. That would usually result in deploying a web application to the following context path:

http://localhost:8081/testDevOps/

Try accessing your service with a URL like this instead:

http://localhost:8081/testDevOps/services/whatever

See the Tomcat configuration reference for Defining a Context.

Christopher Schultz
  • 20,221
  • 9
  • 60
  • 77
  • Hi. Sorry, my bad, I wrote it by hand but in fact I'm accessing it as you suggested (with the URL in sync with the WAR name) – lewap02 Apr 06 '23 at 05:25
  • @lewap02 Okay, please edit the question and correct it. Also, see my comment on the question. I don't see any difference between startup with and without your `init-param`. – Christopher Schultz Apr 06 '23 at 20:15