Solved

How do I resolve Tomcat 6 experiencing a NullPointerException when attempting to invoke contextDestroyed()?

Posted on 2009-07-02
1
455 Views
Last Modified: 2013-12-02
Hi,

I have a context listener extending ServletContextListener. I use contextInitialized() to load in my application's property file and spawn a new thread for managing an external resource; contextDestroyed() is used to gracefully stop this thread from managing the resource.

When Tomcat starts up, contextInitialized() is invoked as expected and the application loads normally. Upon stopping the application / shutting down Tomcat, Catalina throws a NullPointerException when attempting to pass my context listener the "context destroyed" event.

I've included the error from my 'localhost' logfile.

I've checked the "standard" things, such as ensuring my application isn't throwing exceptions, no duplicate .jar's within the lib directories.

Any idea as to why Tomcat is experiencing the NullPointer?
02-Jul-2009 23:00:12 org.apache.catalina.core.StandardContext listenerStop

SEVERE: Exception sending context destroyed event to listener instance of class fivestarlives.ApplicationContextListener

java.lang.NullPointerException

	at fivestarlives.ApplicationContextListener.contextDestroyed(Unknown Source)

	at org.apache.catalina.core.StandardContext.listenerStop(StandardContext.java:3973)

	at org.apache.catalina.core.StandardContext.stop(StandardContext.java:4577)

	at org.apache.catalina.core.ContainerBase.removeChild(ContainerBase.java:924)

	at org.apache.catalina.startup.HostConfig.undeployApps(HostConfig.java:1248)

	at org.apache.catalina.startup.HostConfig.stop(HostConfig.java:1219)

	at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:316)

	at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)

	at org.apache.catalina.core.ContainerBase.stop(ContainerBase.java:1086)

	at org.apache.catalina.core.ContainerBase.stop(ContainerBase.java:1098)

	at org.apache.catalina.core.StandardEngine.stop(StandardEngine.java:448)

	at org.apache.catalina.core.StandardService.stop(StandardService.java:584)

	at org.apache.catalina.core.StandardServer.stop(StandardServer.java:744)

	at org.apache.catalina.startup.Catalina.stop(Catalina.java:633)

	at org.apache.catalina.startup.Catalina.start(Catalina.java:608)

	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

	at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)

	at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)

	at java.lang.reflect.Method.invoke(Unknown Source)

	at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288)

	at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)

Open in new window

0
Comment
Question by:Sabooji
1 Comment
 
LVL 92

Accepted Solution

by:
objects earned 250 total points
ID: 24769002
The NPE is happening in your code, if you compile you class with -g option it will tell you what line number it is occurring on
0

Featured Post

Highfive + Dolby Voice = No More Audio Complaints!

Poor audio quality is one of the top reasons people don’t use video conferencing. Get the crispest, clearest audio powered by Dolby Voice in every meeting. Highfive and Dolby Voice deliver the best video conferencing and audio experience for every meeting and every room.

Join & Write a Comment

Suggested Solutions

Title # Comments Views Activity
wordlen challenge 3 47
Python Assistance 7 35
Groovy:unable to resolve class error 2 31
maven project error 5 21
Verbose logging is used to diagnose garbage collector problems. By default, -verbose:gc output is written to either native_stderr.log or native_stdout.log.   It is also possible to redirect the logs to a user-specified file. This article will de…
Java Flight Recorder and Java Mission Control together create a complete tool chain to continuously collect low level and detailed runtime information enabling after-the-fact incident analysis. Java Flight Recorder is a profiling and event collectio…
Viewers will learn about if statements in Java and their use The if statement: The condition required to create an if statement: Variations of if statements: An example using if statements:
This tutorial covers a practical example of lazy loading technique and early loading technique in a Singleton Design Pattern.

758 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

21 Experts available now in Live!

Get 1:1 Help Now