blob: 930f577de8a0356e4ea6f19c8b211cdc70b77082 [file] [log] [blame]
/*
* Copyright (c) 2010, 2018 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0, which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the
* Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
* version 2 with the GNU Classpath Exception, which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
*/
package com.sun.enterprise.resource.pool.monitor;
import org.glassfish.external.probe.provider.annotations.ProbeListener;
import org.glassfish.external.probe.provider.annotations.ProbeParam;
import org.glassfish.external.statistics.CountStatistic;
import org.glassfish.external.statistics.RangeStatistic;
import org.glassfish.external.statistics.impl.CountStatisticImpl;
import org.glassfish.external.statistics.impl.RangeStatisticImpl;
import org.glassfish.external.statistics.impl.StatisticImpl;
import org.glassfish.gmbal.AMXMetadata;
import org.glassfish.gmbal.Description;
import org.glassfish.gmbal.ManagedAttribute;
import org.glassfish.gmbal.ManagedObject;
import org.glassfish.resourcebase.resources.api.PoolInfo;
/**
* StatsProvider object for Connector Connection pool monitoring
* grouped by application names.
*
* Implements various events related to connector connection pool monitoring
* and provides objects to the calling modules that retrieve monitoring
* information.
*
* @author Shalini M
*/
@AMXMetadata(type="connector-connection-pool-app-mon", group="monitoring")
@ManagedObject
@Description("Connector Connection Pool Application based Statistics")
public class ConnectorConnPoolAppStatsProvider {
private RangeStatisticImpl numConnUsed = new RangeStatisticImpl(
0, 0, 0,
"NumConnUsed", StatisticImpl.UNIT_COUNT, "Provides connection usage " +
"statistics. The total number of connections that are currently being " +
"used, as well as information about the maximum number of connections " +
"that were used (the high water mark).",
System.currentTimeMillis(), System.currentTimeMillis());
private CountStatisticImpl numConnAcquired = new CountStatisticImpl(
"NumConnAcquired", StatisticImpl.UNIT_COUNT, "Number of logical " +
"connections acquired from the pool.");
private CountStatisticImpl numConnReleased = new CountStatisticImpl(
"NumConnReleased", StatisticImpl.UNIT_COUNT, "Number of logical " +
"connections released to the pool.");
private static final String JCA_APP_PROBE_LISTENER = "glassfish:connector-pool:applications:";
private String poolName;
private String appName;
public ConnectorConnPoolAppStatsProvider(PoolInfo poolInfo, String appName) {
this.poolName = poolInfo.getName();
this.appName = appName;
}
public String getPoolName() {
return this.poolName;
}
public String getAppName() {
return this.appName;
}
@ProbeListener(JCA_APP_PROBE_LISTENER + "decrementConnectionUsedEvent")
public void decrementConnectionUsedEvent(
@ProbeParam("poolName") String poolName,
@ProbeParam("appName") String appName) {
// handle the num conn used decrement event
if((poolName != null) && (poolName.equals(this.poolName))) {
if (appName != null && appName.equals(this.appName)) {
//Decrement numConnUsed counter
synchronized (numConnUsed) {
numConnUsed.setCurrent(numConnUsed.getCurrent() - 1);
}
}
}
}
/**
* Connection used event
* @param poolName
* @param appName
*/
@ProbeListener(JCA_APP_PROBE_LISTENER + "connectionUsedEvent")
public void connectionUsedEvent(
@ProbeParam("poolName") String poolName,
@ProbeParam("appName") String appName) {
// handle the connection used event
if((poolName != null) && (poolName.equals(this.poolName))) {
if (appName != null && appName.equals(this.appName)) {
//increment numConnUsed
synchronized (numConnUsed) {
numConnUsed.setCurrent(numConnUsed.getCurrent() + 1);
}
}
}
}
/**
* When a connection is acquired increment counter
*/
@ProbeListener(JCA_APP_PROBE_LISTENER + "connectionAcquiredEvent")
public void connectionAcquiredEvent(
@ProbeParam("poolName") String poolName,
@ProbeParam("appName") String appName) {
if((poolName != null) && (poolName.equals(this.poolName))) {
if (appName != null && appName.equals(this.appName)) {
numConnAcquired.increment();
}
}
}
/**
* When a connection is released increment counter
*/
@ProbeListener(JCA_APP_PROBE_LISTENER + "connectionReleasedEvent")
public void connectionReleasedEvent(
@ProbeParam("poolName") String poolName,
@ProbeParam("appName") String appName) {
if((poolName != null) && (poolName.equals(this.poolName))) {
if (appName != null && appName.equals(this.appName)) {
numConnReleased.increment();
}
}
}
@ManagedAttribute(id="numconnused")
public RangeStatistic getNumConnUsed() {
return numConnUsed;
}
@ManagedAttribute(id="numconnacquired")
public CountStatistic getNumConnAcquired() {
return numConnAcquired;
}
@ManagedAttribute(id="numconnreleased")
public CountStatistic getNumConnReleased() {
return numConnReleased;
}
}