Author: markt
Date: Wed Apr  7 20:19:24 2010
New Revision: 931666

URL: http://svn.apache.org/viewvc?rev=931666&view=rev
Log:
Improve log messages when a potential leak is detected by including the name of 
the offending context

Modified:
    tomcat/tc6.0.x/trunk/   (props changed)
    tomcat/tc6.0.x/trunk/STATUS.txt
    tomcat/tc6.0.x/trunk/java/org/apache/catalina/loader/LocalStrings.properties
    tomcat/tc6.0.x/trunk/java/org/apache/catalina/loader/WebappClassLoader.java
    tomcat/tc6.0.x/trunk/webapps/docs/changelog.xml

Propchange: tomcat/tc6.0.x/trunk/
------------------------------------------------------------------------------
--- svn:mergeinfo (original)
+++ svn:mergeinfo Wed Apr  7 20:19:24 2010
@@ -1 +1 @@
-/tomcat/trunk:601180,606992,612607,630314,640888,652744,653247,666232,673796,673820,677910,683969,683982,684001,684081,684234,684269-684270,685177,687503,687645,689402,690781,691392,691805,692748,693378,694992,695053,695311,696780,696782,698012,698227,698236,698613,699427,699634,701355,709294,709811,709816,710063,710066,710125,710205,711126,711600,712461,712467,713953,714002,718360,719119,719124,719602,719626,719628,720046,720069,721040,721286,721708,721886,723404,723738,726052,727303,728032,728768,728947,729057,729567,729569,729571,729681,729809,729815,729934,730250,730590,731651,732859,732863,734734,740675,740684,742677,742697,742714,744160,744238,746321,746384,746425,747834,747863,748344,750258,750291,750921,751286-751287,751289,751295,752323,753039,757335,757774,758249,758365,758596,758616,758664,759074,761601,762868,762929,762936-762937,763166,763183,763193,763228,763262,763298,763302,763325,763599,763611,763654,763681,763706,764985,764997,765662,768335,769979,770716,77
 
0809,770876,772872,776921,776924,776935,776945,777464,777466,777576,777625,778379,778523-778524,781528,781779,782145,782791,783316,783696,783724,783756,783762,783766,783863,783934,784453,784602,784614,785381,785688,785768,785859,786468,786487,786490,786496,786667,787627,787770,787985,789389,790405,791041,791184,791194,791224,791243,791326,791328,791789,792740,793372,793757,793882,793981,794082,794673,794822,795043,795152,795210,795457,795466,797168,797425,797596,797607,802727,802940,804462,804544,804734,805153,809131,809603,810916,810977,812125,812137,812432,813001,813013,813866,814180,814708,814876,815972,816252,817442,817822,819339,819361,820110,820132,820874,820954,821397,828196,828201,828210,828225,828759,830378-830379,830999,831106,831774,831785,831828,831850,831860,832214,832218,833121,833545,834047,835036,835336,836405,881396,881412,883130,883134,883146,883165,883177,883362,883565,884341,885038,885231,885241,885260,885901,885991,886019,888072,889363,889606,889716,8901
 
39,890265,890349-890350,890417,891185-891187,891583,892198,892341,892415,892464,892555,892812,892814,892817,892843,892887,893321,893493,894580,894586,894805,894831,895013,895045,895057,895191,895392,895703,896370,896384,897380-897381,897776,898126,898256,898468,898527,898555,898558,898718,898836,898906,899284,899348,899420,899653,899769-899770,899783,899788,899792,899916,899918-899919,899935,899949,903916,905020,905151,905722,905728,905735,907311,907513,907538,907652,907819,907825,907864,908002,908721,908754,908759,909097,909206,909212,909525,909636,909869,909875,909887,910266,910370,910442,910471,910974,915226,915737,915861,916097,916141,916157,916170,917598,917633,918093,918594,918684,918787,918792,918799,918885,919851,919914,920025,920055,920596
+/tomcat/trunk:601180,606992,612607,630314,640888,652744,653247,666232,673796,673820,677910,683969,683982,684001,684081,684234,684269-684270,685177,687503,687645,689402,690781,691392,691805,692748,693378,694992,695053,695311,696780,696782,698012,698227,698236,698613,699427,699634,701355,709294,709811,709816,710063,710066,710125,710205,711126,711600,712461,712467,713953,714002,718360,719119,719124,719602,719626,719628,720046,720069,721040,721286,721708,721886,723404,723738,726052,727303,728032,728768,728947,729057,729567,729569,729571,729681,729809,729815,729934,730250,730590,731651,732859,732863,734734,740675,740684,742677,742697,742714,744160,744238,746321,746384,746425,747834,747863,748344,750258,750291,750921,751286-751287,751289,751295,752323,753039,757335,757774,758249,758365,758596,758616,758664,759074,761601,762868,762929,762936-762937,763166,763183,763193,763228,763262,763298,763302,763325,763599,763611,763654,763681,763706,764985,764997,765662,768335,769979,770716,77
 
0809,770876,772872,776921,776924,776935,776945,777464,777466,777576,777625,778379,778523-778524,781528,781779,782145,782791,783316,783696,783724,783756,783762,783766,783863,783934,784453,784602,784614,785381,785688,785768,785859,786468,786487,786490,786496,786667,787627,787770,787985,789389,790405,791041,791184,791194,791224,791243,791326,791328,791789,792740,793372,793757,793882,793981,794082,794673,794822,795043,795152,795210,795457,795466,797168,797425,797596,797607,802727,802940,804462,804544,804734,805153,809131,809603,810916,810977,812125,812137,812432,813001,813013,813866,814180,814708,814876,815972,816252,817442,817822,819339,819361,820110,820132,820874,820954,821397,828196,828201,828210,828225,828759,830378-830379,830999,831106,831774,831785,831828,831850,831860,832214,832218,833121,833545,834047,835036,835336,836405,881396,881412,883130,883134,883146,883165,883177,883362,883565,884341,885038,885231,885241,885260,885901,885991,886019,888072,889363,889606,889716,8901
 
39,890265,890349-890350,890417,891185-891187,891583,892198,892341,892415,892464,892555,892812,892814,892817,892843,892887,893321,893493,894580,894586,894805,894831,895013,895045,895057,895191,895392,895703,896370,896384,897380-897381,897776,898126,898256,898468,898527,898555,898558,898718,898836,898906,899284,899348,899420,899653,899769-899770,899783,899788,899792,899916,899918-899919,899935,899949,903916,905020,905151,905722,905728,905735,907311,907513,907538,907652,907819,907825,907864,908002,908721,908754,908759,909097,909206,909212,909525,909636,909869,909875,909887,910266,910370,910442,910471,910974,915226,915737,915861,916097,916141,916157,916170,917598,917633,918093,918594,918684,918787,918792,918799,918885,919851,919914,920025,920055,920298,920596

Modified: tomcat/tc6.0.x/trunk/STATUS.txt
URL: 
http://svn.apache.org/viewvc/tomcat/tc6.0.x/trunk/STATUS.txt?rev=931666&r1=931665&r2=931666&view=diff
==============================================================================
--- tomcat/tc6.0.x/trunk/STATUS.txt (original)
+++ tomcat/tc6.0.x/trunk/STATUS.txt Wed Apr  7 20:19:24 2010
@@ -99,12 +99,6 @@ PATCHES PROPOSED TO BACKPORT:
   +1: kkolinko, markt
   -1:
 
-* Improve log messages when a potential leak is detected by including the name
-  of the offending context
-  http://svn.apache.org/viewvc?view=revision&revision=920298
-  +1: markt, kkolinko, kfujino
-  -1: 
-
 * Fix https://issues.apache.org/bugzilla/show_bug.cgi?id=48629
   Allow user names as well as DNs to be used with the nested role search
   Add roleNested to the docs

Modified: 
tomcat/tc6.0.x/trunk/java/org/apache/catalina/loader/LocalStrings.properties
URL: 
http://svn.apache.org/viewvc/tomcat/tc6.0.x/trunk/java/org/apache/catalina/loader/LocalStrings.properties?rev=931666&r1=931665&r2=931666&view=diff
==============================================================================
--- 
tomcat/tc6.0.x/trunk/java/org/apache/catalina/loader/LocalStrings.properties 
(original)
+++ 
tomcat/tc6.0.x/trunk/java/org/apache/catalina/loader/LocalStrings.properties 
Wed Apr  7 20:19:24 2010
@@ -29,23 +29,23 @@ standardLoader.removeRepository=Removing
 standardLoader.starting=Starting this Loader
 standardLoader.stopping=Stopping this Loader
 webappClassLoader.illegalJarPath=Illegal JAR entry detected with name {0}
-webappClassLoader.jdbcRemoveFailed=JDBC driver de-registration failed
-webappClassLoader.jdbcRemoveStreamError=Exception closing input stream during 
JDBC driver de-registration
+webappClassLoader.jdbcRemoveFailed=JDBC driver de-registration failed for web 
application [{0}]
+webappClassLoader.jdbcRemoveStreamError=Exception closing input stream during 
JDBC driver de-registration for web application [{0}]
 webappClassLoader.stopped=Illegal access: this web application instance has 
been stopped already.  Could not load {0}.  The eventual following stack trace 
is caused by an error thrown for debugging purposes as well as to attempt to 
terminate the thread which caused the illegal access, and has no functional 
impact.
 webappClassLoader.readError=Resource read error: Could not load {0}.
-webappClassLoader.clearJbdc=A web application registered the JBDC driver [{0}] 
but failed to unregister it when the web application was stopped. To prevent a 
memory leak, the JDBC Driver has been forcibly unregistered.
-webappClassLoader.clearReferencesResourceBundlesCount=Removed [{0}] 
ResourceBundle references from the cache
-webappClassLoader.clearReferencesResourceBundlesFail=Failed to clear 
ResourceBundle references
-webappClassLoader.clearRmiInfo=Failed to find class sun.rmi.transport.Target 
to clear context class loader. This is expected on non-Sun JVMs.
-webappClassLoader.clearRmiFail=Failed to clear context class loader referenced 
from sun.rmi.transport.Target 
-webappClassLoader.clearThreadLocalDebug=A web application created a 
ThreadLocal with key of type [{0}] (value [{1}]). The ThreadLocal has been 
correctly set to null and the key will be removed by GC. However, to simplify 
the process of tracing memory leaks, the key has been forcibly removed.
-webappClassLoader.clearThreadLocal=A web application created a ThreadLocal 
with key of type [{0}] (value [{1}]) and a value of type [{2}] (value [{3}]) 
but failed to remove it when the web application was stopped. To prevent a 
memory leak, the ThreadLocal has been forcibly removed.
-webappClassLoader.clearThreadLocalFail=Failed to clear ThreadLocal references
-webappClassLoader.stopThreadFail=Failed to terminate thread named [{0}]
-webappClassLoader.stopTimerThreadFail=Failed to terminate TimerThread named 
[{0}]
+webappClassLoader.clearJbdc=The web application [{0}] registered the JBDC 
driver [{1}] but failed to unregister it when the web application was stopped. 
To prevent a memory leak, the JDBC Driver has been forcibly unregistered.
+webappClassLoader.clearReferencesResourceBundlesCount=Removed [{0}] 
ResourceBundle references from the cache for web application [{1}]
+webappClassLoader.clearReferencesResourceBundlesFail=Failed to clear 
ResourceBundle references for web application [{0}]
+webappClassLoader.clearRmiInfo=Failed to find class sun.rmi.transport.Target 
to clear context class loader for web application [{0}]. This is expected on 
non-Sun JVMs.
+webappClassLoader.clearRmiFail=Failed to clear context class loader referenced 
from sun.rmi.transport.Target for web application [{0}]
+webappClassLoader.clearThreadLocalDebug=The web application [{0}] created a 
ThreadLocal with key of type [{1}] (value [{2}]). The ThreadLocal has been 
correctly set to null and the key will be removed by GC. However, to simplify 
the process of tracing memory leaks, the key has been forcibly removed.
+webappClassLoader.clearThreadLocal=The web application [{0}] created a 
ThreadLocal with key of type [{1}] (value [{2}]) and a value of type [{3}] 
(value [{4}]) but failed to remove it when the web application was stopped. To 
prevent a memory leak, the ThreadLocal has been forcibly removed.
+webappClassLoader.clearThreadLocalFail=Failed to clear ThreadLocal references 
for web application [{0}]
+webappClassLoader.stopThreadFail=Failed to terminate thread named [{0}] for 
web application [{1}]
+webappClassLoader.stopTimerThreadFail=Failed to terminate TimerThread named 
[{0}] for web application [{1}]
 webappClassLoader.validationErrorJarPath=Unable to validate JAR entry with 
name {0}
-webappClassLoader.warnThread=A web application appears to have started a 
thread named [{0}] but has failed to stop it. This is very likely to create a 
memory leak.
-webappClassLoader.warnTimerThread=A web application appears to have started a 
TimerThread named [{0}] via the java.util.Timer API but has failed to stop it. 
To prevent a memory leak, the timer (and hence the associated thread) has been 
forcibly cancelled. 
+webappClassLoader.warnThread=The web application [{0}] appears to have started 
a thread named [{1}] but has failed to stop it. This is very likely to create a 
memory leak. 
+webappClassLoader.warnTimerThread=The web application [{0}] appears to have 
started a TimerThread named [{1}] via the java.util.Timer API but has failed to 
stop it. To prevent a memory leak, the timer (and hence the associated thread) 
has been forcibly canceled. 
 webappClassLoader.wrongVersion=(unable to load class {0})
 webappLoader.addRepository=Adding repository {0}
 webappLoader.deploy=Deploying class repositories to work directory {0}

Modified: 
tomcat/tc6.0.x/trunk/java/org/apache/catalina/loader/WebappClassLoader.java
URL: 
http://svn.apache.org/viewvc/tomcat/tc6.0.x/trunk/java/org/apache/catalina/loader/WebappClassLoader.java?rev=931666&r1=931665&r2=931666&view=diff
==============================================================================
--- tomcat/tc6.0.x/trunk/java/org/apache/catalina/loader/WebappClassLoader.java 
(original)
+++ tomcat/tc6.0.x/trunk/java/org/apache/catalina/loader/WebappClassLoader.java 
Wed Apr  7 20:19:24 2010
@@ -70,6 +70,7 @@ import org.apache.catalina.LifecycleList
 import org.apache.catalina.util.StringManager;
 import org.apache.jasper.servlet.JasperLoader;
 import org.apache.naming.JndiPermission;
+import org.apache.naming.resources.ProxyDirContext;
 import org.apache.naming.resources.Resource;
 import org.apache.naming.resources.ResourceAttributes;
 import org.apache.tomcat.util.IntrospectionUtils;
@@ -458,6 +459,16 @@ public class WebappClassLoader
      */
     private boolean clearReferencesLogFactoryRelease = true;
 
+    
+    /**
+     * Name of associated context used with logging to associate messages with
+     * the right web application. Particularly useful for the clear references
+     * messages. Defaults to unknown but if standard Tomcat components are used
+     * it will be updated during initialisation from the resources.
+     */
+    private String contextName = "unknown";
+
+
     // ------------------------------------------------------------- Properties
 
 
@@ -478,6 +489,9 @@ public class WebappClassLoader
 
         this.resources = resources;
 
+        if (resources instanceof ProxyDirContext) {
+            contextName = ((ProxyDirContext) resources).getContextName();
+        }
     }
 
 
@@ -1656,7 +1670,7 @@ public class WebappClassLoader
         // Clearing references should be done before setting started to
         // false, due to possible side effects
         clearReferences();
-
+        
         started = false;
         
         int length = files.length;
@@ -1820,18 +1834,21 @@ public class WebappClassLoader
             List<String> driverNames = (List<String>) obj.getClass().getMethod(
                     "clearJdbcDriverRegistrations").invoke(obj);
             for (String name : driverNames) {
-                log.error(sm.getString("webappClassLoader.clearJbdc", name));
+                log.error(sm.getString("webappClassLoader.clearJbdc",
+                        contextName, name));
             }
         } catch (Exception e) {
             // So many things to go wrong above...
-            log.warn(sm.getString("webappClassLoader.jdbcRemoveFailed"), e);
+            log.warn(sm.getString(
+                    "webappClassLoader.jdbcRemoveFailed", contextName), e);
         } finally {
             if (is != null) {
                 try {
                     is.close();
                 } catch (IOException ioe) {
                     log.warn(sm.getString(
-                            "webappClassLoader.jdbcRemoveStreamError"), ioe);
+                            "webappClassLoader.jdbcRemoveStreamError",
+                            contextName), ioe);
                 }
             }
         }
@@ -1996,7 +2013,7 @@ public class WebappClassLoader
                     }
 
                     log.error(sm.getString("webappClassLoader.warnThread",
-                            thread.getName()));
+                            contextName, thread.getName()));
                     
                     // Don't try an stop the threads unless explicitly
                     // configured to do so
@@ -2026,19 +2043,19 @@ public class WebappClassLoader
                     } catch (SecurityException e) {
                         log.warn(sm.getString(
                                 "webappClassLoader.stopThreadFail",
-                                thread.getName()), e);
+                                thread.getName(), contextName), e);
                     } catch (NoSuchFieldException e) {
                         log.warn(sm.getString(
                                 "webappClassLoader.stopThreadFail",
-                                thread.getName()), e);
+                                thread.getName(), contextName), e);
                     } catch (IllegalArgumentException e) {
                         log.warn(sm.getString(
                                 "webappClassLoader.stopThreadFail",
-                                thread.getName()), e);
+                                thread.getName(), contextName), e);
                     } catch (IllegalAccessException e) {
                         log.warn(sm.getString(
                                 "webappClassLoader.stopThreadFail",
-                                thread.getName()), e);
+                                thread.getName(), contextName), e);
                     }
 
                     // This method is deprecated and for good reason. This is
@@ -2078,24 +2095,24 @@ public class WebappClassLoader
             }
             
             log.error(sm.getString("webappClassLoader.warnTimerThread",
-                    thread.getName()));
+                    contextName, thread.getName()));
 
         } catch (NoSuchFieldException e) {
             log.warn(sm.getString(
                     "webappClassLoader.stopTimerThreadFail",
-                    thread.getName()), e);
+                    thread.getName(), contextName), e);
         } catch (IllegalAccessException e) {
             log.warn(sm.getString(
                     "webappClassLoader.stopTimerThreadFail",
-                    thread.getName()), e);
+                    thread.getName(), contextName), e);
         } catch (NoSuchMethodException e) {
             log.warn(sm.getString(
                     "webappClassLoader.stopTimerThreadFail",
-                    thread.getName()), e);
+                    thread.getName(), contextName), e);
         } catch (InvocationTargetException e) {
             log.warn(sm.getString(
                     "webappClassLoader.stopTimerThreadFail",
-                    thread.getName()), e);
+                    thread.getName(), contextName), e);
         }
     }
 
@@ -2131,19 +2148,26 @@ public class WebappClassLoader
                 }
             }
         } catch (SecurityException e) {
-            log.warn(sm.getString("webappClassLoader.clearThreadLocalFail"), 
e);
+            log.warn(sm.getString("webappClassLoader.clearThreadLocalFail",
+                    contextName), e);
         } catch (NoSuchFieldException e) {
-            log.warn(sm.getString("webappClassLoader.clearThreadLocalFail"), 
e);
+            log.warn(sm.getString("webappClassLoader.clearThreadLocalFail",
+                    contextName), e);
         } catch (ClassNotFoundException e) {
-            log.warn(sm.getString("webappClassLoader.clearThreadLocalFail"), 
e);
+            log.warn(sm.getString("webappClassLoader.clearThreadLocalFail",
+                    contextName), e);
         } catch (IllegalArgumentException e) {
-            log.warn(sm.getString("webappClassLoader.clearThreadLocalFail"), 
e);
+            log.warn(sm.getString("webappClassLoader.clearThreadLocalFail",
+                    contextName), e);
         } catch (IllegalAccessException e) {
-            log.warn(sm.getString("webappClassLoader.clearThreadLocalFail"), 
e);
+            log.warn(sm.getString("webappClassLoader.clearThreadLocalFail",
+                    contextName), e);
         } catch (NoSuchMethodException e) {
-            log.warn(sm.getString("webappClassLoader.clearThreadLocalFail"), 
e);
+            log.warn(sm.getString("webappClassLoader.clearThreadLocalFail",
+                    contextName), e);
         } catch (InvocationTargetException e) {
-            log.warn(sm.getString("webappClassLoader.clearThreadLocalFail"), 
e);
+            log.warn(sm.getString("webappClassLoader.clearThreadLocalFail",
+                    contextName), e);
         }       
     }
 
@@ -2183,14 +2207,15 @@ public class WebappClassLoader
                             remove = true;
                         }
                         if (remove) {
-                            Object[] args = new Object[4];
+                            Object[] args = new Object[5];
+                            args[0] = contextName;
                             if (key != null) {
-                                args[0] = key.getClass().getCanonicalName();
-                                args[1] = key.toString();
+                                args[1] = key.getClass().getCanonicalName();
+                                args[2] = key.toString();
                             }
                             if (value != null) {
-                                args[2] = value.getClass().getCanonicalName();
-                                args[3] = value.toString();
+                                args[3] = value.getClass().getCanonicalName();
+                                args[4] = value.toString();
                             }
                             if (value == null) {
                                 if (log.isDebugEnabled()) {
@@ -2302,15 +2327,20 @@ public class WebappClassLoader
                 }
             }
         } catch (ClassNotFoundException e) {
-            log.info(sm.getString("webappClassLoader.clearRmiInfo"), e);
+            log.info(sm.getString("webappClassLoader.clearRmiInfo",
+                    contextName), e);
         } catch (SecurityException e) {
-            log.warn(sm.getString("webappClassLoader.clearRmiFail"), e);
+            log.warn(sm.getString("webappClassLoader.clearRmiFail",
+                    contextName), e);
         } catch (NoSuchFieldException e) {
-            log.warn(sm.getString("webappClassLoader.clearRmiFail"), e);
+            log.warn(sm.getString("webappClassLoader.clearRmiFail",
+                    contextName), e);
         } catch (IllegalArgumentException e) {
-            log.warn(sm.getString("webappClassLoader.clearRmiFail"), e);
+            log.warn(sm.getString("webappClassLoader.clearRmiFail",
+                    contextName), e);
         } catch (IllegalAccessException e) {
-            log.warn(sm.getString("webappClassLoader.clearRmiFail"), e);
+            log.warn(sm.getString("webappClassLoader.clearRmiFail",
+                    contextName), e);
         }
     }
     
@@ -2374,25 +2404,30 @@ public class WebappClassLoader
             if (countRemoved > 0 && log.isDebugEnabled()) {
                 log.debug(sm.getString(
                         
"webappClassLoader.clearReferencesResourceBundlesCount",
-                        Integer.valueOf(countRemoved)));
+                        Integer.valueOf(countRemoved), contextName));
             }
         } catch (SecurityException e) {
             log.error(sm.getString(
-                    "webappClassLoader.clearReferencesResourceBundlesFail"), 
e);
+                    "webappClassLoader.clearReferencesResourceBundlesFail",
+                    contextName), e);
         } catch (NoSuchFieldException e) {
             if (System.getProperty("java.vendor").startsWith("Sun")) {
                 log.error(sm.getString(
-                "webappClassLoader.clearReferencesResourceBundlesFail"), e);
+                "webappClassLoader.clearReferencesResourceBundlesFail",
+                contextName), e);
             } else {
                 log.debug(sm.getString(
-                "webappClassLoader.clearReferencesResourceBundlesFail"), e);
+                "webappClassLoader.clearReferencesResourceBundlesFail",
+                contextName), e);
             }
         } catch (IllegalArgumentException e) {
             log.error(sm.getString(
-                    "webappClassLoader.clearReferencesResourceBundlesFail"), 
e);
+                    "webappClassLoader.clearReferencesResourceBundlesFail",
+                    contextName), e);
         } catch (IllegalAccessException e) {
             log.error(sm.getString(
-                    "webappClassLoader.clearReferencesResourceBundlesFail"), 
e);
+                    "webappClassLoader.clearReferencesResourceBundlesFail",
+                    contextName), e);
         }
     }
 

Modified: tomcat/tc6.0.x/trunk/webapps/docs/changelog.xml
URL: 
http://svn.apache.org/viewvc/tomcat/tc6.0.x/trunk/webapps/docs/changelog.xml?rev=931666&r1=931665&r2=931666&view=diff
==============================================================================
--- tomcat/tc6.0.x/trunk/webapps/docs/changelog.xml (original)
+++ tomcat/tc6.0.x/trunk/webapps/docs/changelog.xml Wed Apr  7 20:19:24 2010
@@ -39,6 +39,14 @@
  Catalina, Coyote, Jasper, Cluster, Webapps, Other
 -->
 <section name="Tomcat 6.0.27 (jfclere)">
+  <subsection name="Catalina">
+    <changelog>
+      <add>
+        Include context name when reporting memory leaks to aid root cause
+        identification. (markt)
+      </add>
+    </changelog>
+  </subsection>
   <subsection name="Other">
     <changelog>
       <update>Update to Commons Daemon 1.0.2. Use service launcher (procrun)



---------------------------------------------------------------------
To unsubscribe, e-mail: dev-unsubscr...@tomcat.apache.org
For additional commands, e-mail: dev-h...@tomcat.apache.org

Reply via email to