/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.
*
* The contents of this file are subject to the terms of either the GNU
* General Public License Version 2 only ("GPL") or the Common Development
* and Distribution License("CDDL") (collectively, the "License"). You
* may not use this file except in compliance with the License. You can obtain
* a copy of the License at https://glassfish.dev.java.net/public/CDDL+GPL.html
* or glassfish/bootstrap/legal/LICENSE.txt. See the License for the specific
* language governing permissions and limitations under the License.
*
* When distributing the software, include this License Header Notice in each
* file and include the License file at glassfish/bootstrap/legal/LICENSE.txt.
* Sun designates this particular file as subject to the "Classpath" exception
* as provided by Sun in the GPL Version 2 section of the License file that
* accompanied this code. If applicable, add the following below the License
* Header, with the fields enclosed by brackets [] replaced by your own
* identifying information: "Portions Copyrighted [year]
* [name of copyright owner]"
*
* Contributor(s):
*
* If you wish your version of this file to be governed by only the CDDL or
* only the GPL Version 2, indicate your decision by adding "[Contributor]
* elects to include this software in this distribution under the [CDDL or GPL
* Version 2] license." If you don't indicate a single choice of license, a
* recipient has the option to distribute your version of this file under
* either the CDDL, the GPL Version 2 or to extend the choice of license to
* its licensees as provided above. However, if you add GPL Version 2 code
* and therefore, elected the GPL Version 2 license, then the option applies
* only if the new code is made subject to such option by the copyright
* holder.
*/
/*
* DebugMonitor.java
*
* Created on January 14, 2003, 1:10 PM
*/
package com.sun.enterprise.web;
import java.util.logging.*;
import com.sun.logging.*;
import java.util.Hashtable;
import java.util.Enumeration;
import org.apache.catalina.Context;
import org.apache.catalina.Container;
import org.apache.catalina.Engine;
import org.apache.catalina.Manager;
//FIXME remove after testing
//import com.sun.appserv.ee.web.sessmgmt.HAManagerBase;
import org.apache.catalina.session.PersistentManagerBase;
import org.apache.catalina.session.StandardManager;
/**
*
* @author Administrator
*/
public final class DebugMonitor extends java.util.TimerTask {
private Hashtable _instances = null;
private final EmbeddedWebContainer _embedded;
private static final Logger _logger;
private WebContainer webContainer = null;
static
{
_logger=LogDomains.getLogger(LogDomains.WEB_LOGGER);
}
/** Creates a new instance of DebugMonitor */
public DebugMonitor() {
_embedded = null;
}
/** Creates a new instance of DebugMonitor */
public DebugMonitor(EmbeddedWebContainer embedded) {
_embedded = embedded;
}
public String getApplicationId(Context ctx) {
com.sun.enterprise.web.WebModule wm =
(com.sun.enterprise.web.WebModule)ctx;
return wm.getID();
}
public String getApplicationName(Context ctx) {
return ctx.getName();
}
public void run() {
try {
Engine[] engines = _embedded.getEngines();
for(int h=0; h<engines.length; h++) {
Container engine = (Container) engines[h];
Container[] hosts = engine.findChildren();
for(int i=0; i<hosts.length; i++) {
Container nextHost = hosts[i];
Container [] webModules = nextHost.findChildren();
for (int j=0; j<webModules.length; j++) {
Container nextWebModule = webModules[j];
Context ctx = (Context)nextWebModule;
//this code gets managers
String webAppName = this.getApplicationName(ctx);
Manager nextManager = nextWebModule.getManager();
_logger.finest("webAppName = " + webAppName);
if(nextManager instanceof StandardManager) {
} else {
_logger.log(Level.SEVERE, "MONITORING::" + webAppName + ": " +
((PersistentManagerBase)nextManager).getMonitorAttributeValues() );
}
}
}
}
} catch (Throwable th) {
_logger.log(Level.SEVERE, "Exception thrown", th);
}
}
}
|