Mark,

A few extra inline comments/...

On 11/25/25 3:01 AM, Mark Thomas wrote:
On 25/11/2025 04:14, Harshit Sharma wrote:
 2.

    What is the recommended deployment strategy for production
    environments to avoid memory leaks when updating WAR files??

Don't deploy applications with memory leaks. This is an application problem, not a Tomcat problem.

Please note that the above comment about "applications with memory leaks" was intended to treat "not shutting-down cleanly" as an application leak. If you can run the application (without restarts) for 10 years without leaking memory, that's great. But if you reload the application and now you have 2x the number of classes loaded permanently into the JVM's memory space, this should be considered an "application with a memory leak".

The link at the very bottom of Mark's reply is a presentation showing how to find memory leaks such as this. It's 29 pages are deceptively simple, but it's a deep well. To debug these kinds of issues usually requires the use of tools like debuggers and memory profilers. Become familiar with their use and you will be able to find and fix these kinds of leaks.

 3.

    Are there known issues with Tomcat 7.0.41 related to classloader
    leaks during redeployment??

Not that match your description of a leak every reload (there are a couple where you might see a leak on the first but not subsequent reloads).

There have been multiple improvements to Tomcat's JreMemoryLeakPreventionListener since 7.0.41 which helps prevent memory leaks due to the application's use of various parts of the JRE.

 4.

    What monitoring or preventive measures can we implement to detect
    and mitigate this issue before it causes production outages??

Update to a supported version of Tomcat. The latest 9.0.x release will be the minimum work since it still supports Java EE. Be sure to read the migration guides:

https://tomcat.apache.org/migration.html

There is at least one commercial vendor that offers support for Tomcat 7 but even then the supported version is based on 7.0.109 so you'd have a significant update to do anyway. I doubt updating to 9.0.x would be much more effort.

+1

We suspect the combination of symlinked WAR files, autoDeploy="true", and no-restart deployments is preventing proper cleanup of old classloaders, but we'd like to understand the root cause and implement a robust solution.

Those suspicions are very likely wrong.

Any insights, best practices, or references to similar issues would be greatly appreciated.

https://tomcat.apache.org/presentations/2010-08-05-javaone-Memory- Leaks-60mins.pdf

Please definitely read this. But maybe, first, take some time to see if your application runs under Tomcat 9. It probably will.

-chris


---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to