/* * NOTE: This copyright does *not* cover user programs that use HQ * program services by normal system calls through the application * program interfaces provided as part of the Hyperic Plug-in Development * Kit or the Hyperic Client Development Kit - this is merely considered * normal use of the program, and does *not* fall under the heading of * "derived work". * * Copyright (C) [2004, 2005, 2006], Hyperic, Inc. * This file is part of HQ. * * HQ is free software; you can redistribute it and/or modify * it under the terms version 2 of the GNU General Public License as * published by the Free Software Foundation. This program is distributed * in the hope that it will be useful, but WITHOUT ANY WARRANTY; without * even the implied warranty of MERCHANTABILITY or FITNESS FOR A * PARTICULAR PURPOSE. See the GNU General Public License for more * details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 * USA. */ package org.hyperic.hq.plugin.websphere; import com.ibm.websphere.management.AdminClient; import javax.management.ObjectName; import javax.management.j2ee.statistics.Stats; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.hyperic.hq.product.PluginException; public class WebappCollector extends WebsphereCollector { private static final Log log = LogFactory.getLog(WebappCollector.class.getName()); private ObjectName sessionStatsObjectName = null; private static final String[] sessionStatNames = { "CreateCount", "InvalidateCount", "LifeTime", "ActiveCount", "LiveCount", "NoRoomForNewSessionCount", "CacheDiscardCount", "ExternalReadTime", "ExternalReadSize", "ExternalWriteTime", "ExternalWriteSize", "AffinityBreakCount", "TimeSinceLastActivated", "TimeoutInvalidationCount", "ActivateNonExistSessionCount", "SessionObjectSize" }; protected void init(AdminClient mServer) throws PluginException { String module = getModuleName(); int ix = module.indexOf('#'); if (ix == -1) { throw new PluginException("Malformed webapp name '" + module + "'"); } String app = module.substring(0, ix); String war = module.substring(ix + 1); ObjectName name = newObjectNamePattern("j2eeType=WebModule," + "J2EEApplication=" + app + "," + "name=" + war + "," + getProcessAttributes()); setObjectName(resolve(mServer, name)); // for session manager name = newObjectNamePattern("name=" + getModuleName() + "," + "type=SessionManager," + getProcessAttributes()); // better catch this resolve, don't want to // fail if stats are not found. try { sessionStatsObjectName = resolve(mServer, name); } catch (PluginException e) { log.debug("Can't resolve session stats object name. " + "Not collecting session statistics."); } } public void collect(AdminClient mServer) throws PluginException { Object servlets = getAttribute(mServer, getObjectName(), "servlets"); if (servlets == null) { setAvailability(false); } else { setAvailability(true); if (sessionStatsObjectName == null) { init(mServer); } Stats stats = (Stats) getStats(mServer, sessionStatsObjectName); if (stats != null) { for (int i = 0; i < sessionStatNames.length; i++) { setValue(sessionStatNames[i], getStatCount(stats, sessionStatNames[i])); } } else { log.debug("No session manager stats"); } } } }