blob: 29a533cc9bfeebbfdf821269d3cfc1f899542b20 [file] [log] [blame]
/*
* =========================================================================
* Copyright (c) 2012-2014 Pivotal Software, Inc. All Rights Reserved.
* This product is protected by U.S. and international copyright
* and intellectual property laws. Pivotal products are covered by
* more patents listed at http://www.pivotal.io/patents.
* ========================================================================
*/
package com.vmware.gemfire.tools.pulse.internal.service;
import javax.servlet.http.HttpServletRequest;
import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Component;
import org.springframework.stereotype.Service;
import com.vmware.gemfire.tools.pulse.internal.data.Cluster;
import com.vmware.gemfire.tools.pulse.internal.data.Repository;
import com.vmware.gemfire.tools.pulse.internal.json.JSONArray;
import com.vmware.gemfire.tools.pulse.internal.json.JSONException;
import com.vmware.gemfire.tools.pulse.internal.json.JSONObject;
import com.vmware.gemfire.tools.pulse.internal.util.StringUtils;
/**
* Class MemberKeyStatisticsService
*
* This class contains implementations of getting Member's CPU, Memory and Read
* Write details
*
* @author Sachin K
* @since version 7.5
*/
@Component
@Service("MemberKeyStatistics")
@Scope("singleton")
public class MemberKeyStatisticsService implements PulseService {
public JSONObject execute(final HttpServletRequest request) throws Exception {
// get cluster object
Cluster cluster = Repository.get().getCluster();
// json object to be sent as response
JSONObject responseJSON = new JSONObject();
try {
JSONObject requestDataJSON = new JSONObject(
request.getParameter("pulseData"));
String memberName = requestDataJSON.getJSONObject("MemberKeyStatistics")
.getString("memberName");
Cluster.Member clusterMember = cluster.getMember(StringUtils
.makeCompliantName(memberName));
if (clusterMember != null) {
// response
responseJSON
.put(
"cpuUsageTrend",
new JSONArray(
clusterMember
.getMemberStatisticTrend(Cluster.Member.MEMBER_STAT_CPU_USAGE_SAMPLE)));
responseJSON
.put(
"memoryUsageTrend",
new JSONArray(
clusterMember
.getMemberStatisticTrend(Cluster.Member.MEMBER_STAT_HEAP_USAGE_SAMPLE)));
responseJSON
.put(
"readPerSecTrend",
new JSONArray(
clusterMember
.getMemberStatisticTrend(Cluster.Member.MEMBER_STAT_GETS_PER_SECOND)));
responseJSON
.put(
"writePerSecTrend",
new JSONArray(
clusterMember
.getMemberStatisticTrend(Cluster.Member.MEMBER_STAT_PUTS_PER_SECOND)));
}
// Send json response
return responseJSON;
} catch (JSONException e) {
throw new Exception(e);
}
}
}