Ad

Why Does Tomcat 5.5 (with Java 1.4, Running On Windows XP 32-bit) Suddenly Hang?

- 1 answer

I've been running Tomcat 5.5 with Java 1.4 for a while now with a huge webapp. Most of the time it runs fine, but sometimes it will just hang, with no exception generated, and no apparant way of getting it to run again other than re-starting Tomcat. The tomcat instance is allowed a gigabyte of memory on the heap, but rarely exceeds 300 MB. Has anyone else run into this issue, and is there a solution for it?

For clarification: I determined how much memory it is using via Task Manager and via Eclipse (I've also tried running it outside of Eclipse, but get the same problem eventually, though it takes a little longer). With Eclipse, I look at the memory allocated via its little (optional) memory pane and the amount allocated to javaw.exe via the task manager. I use the sysdeo? tomcat plugin for Eclipse.

Ad

Answer

For any jvm process, force a thread dump. In windows, this can be done with CTRL-BREAK, I believe, in the console window.

In *nix, it is almost always "kill -3 jvm-pid".

This may show if you have threads waiting on db connection pool/thread pool, etc.

Another thing to check out is how many connections you have currently to the JVM -- either use NETSTAT or SysInternals utility such as tcpconn/tcpview (google it).

Also, try to run with the verbose:gc JVM flag. For Sun's JVM, run like "java -verbose:gc". This will show your garbage collections. If it is collecting a lot (FULL COLLECTIONS, expecially) then you probably have a memory leak. The full collections are costly, especially on large heaps like that.

How are you determining that only 300mb are being used?

Ad
source: stackoverflow.com
Ad