use of com.navercorp.pinpoint.web.vo.Range in project pinpoint by naver.
the class AgentStatisticsController method selectAgentCount.
@RequestMapping(value = "/selectAgentCount", method = RequestMethod.GET, params = { "from", "to" })
@ResponseBody
public List<AgentCountStatistics> selectAgentCount(@RequestParam("from") long from, @RequestParam("to") long to) {
Range range = new Range(DateUtils.timestampToMidNight(from), DateUtils.timestampToMidNight(to), true);
List<AgentCountStatistics> agentCountStatisticsList = agentStatisticsService.selectAgentCount(range);
Collections.sort(agentCountStatisticsList, new Comparator<AgentCountStatistics>() {
@Override
public int compare(AgentCountStatistics o1, AgentCountStatistics o2) {
if (o1.getTimestamp() > o2.getTimestamp()) {
return -1;
} else {
return 1;
}
}
});
return agentCountStatisticsList;
}
use of com.navercorp.pinpoint.web.vo.Range in project pinpoint by naver.
the class AgentStatDataCollector method collect.
@Override
public void collect() {
if (init.get()) {
return;
}
Range range = Range.createUncheckedRange(timeSlotEndTime - slotInterval, timeSlotEndTime);
List<String> agentIds = applicationIndexDao.selectAgentIds(application.getName());
for (String agentId : agentIds) {
List<JvmGcBo> jvmGcBos = jvmGcDao.getAgentStatList(agentId, range);
List<CpuLoadBo> cpuLoadBos = cpuLoadDao.getAgentStatList(agentId, range);
long totalHeapSize = 0;
long usedHeapSize = 0;
long jvmCpuUsaged = 0;
for (JvmGcBo jvmGcBo : jvmGcBos) {
totalHeapSize += jvmGcBo.getHeapMax();
usedHeapSize += jvmGcBo.getHeapUsed();
}
for (CpuLoadBo cpuLoadBo : cpuLoadBos) {
jvmCpuUsaged += cpuLoadBo.getJvmCpuLoad() * 100;
}
if (!jvmGcBos.isEmpty()) {
long percent = calculatePercent(usedHeapSize, totalHeapSize);
agentHeapUsageRate.put(agentId, percent);
long accruedLastGcCount = jvmGcBos.get(0).getGcOldCount();
long accruedFirstGcCount = jvmGcBos.get(jvmGcBos.size() - 1).getGcOldCount();
agentGcCount.put(agentId, accruedLastGcCount - accruedFirstGcCount);
}
if (!cpuLoadBos.isEmpty()) {
long percent = calculatePercent(jvmCpuUsaged, 100 * cpuLoadBos.size());
agentJvmCpuUsageRate.put(agentId, percent);
}
}
init.set(true);
}
use of com.navercorp.pinpoint.web.vo.Range in project pinpoint by naver.
the class MemoryAgentStatisticsDaoTest method simpleTest.
@Test
public void simpleTest() throws Exception {
MemoryAgentStatisticsDao dao = new MemoryAgentStatisticsDao();
for (AgentCountStatistics testData : testDataList) {
dao.insertAgentCount(testData);
}
Range range = new Range(660L, 1320L);
List<AgentCountStatistics> agentCountStatisticses = dao.selectAgentCount(range);
Assert.assertEquals(7, agentCountStatisticses.size());
range = new Range(7100L, System.currentTimeMillis());
agentCountStatisticses = dao.selectAgentCount(range);
Assert.assertEquals(30, agentCountStatisticses.size());
range = new Range(0L, System.currentTimeMillis());
agentCountStatisticses = dao.selectAgentCount(range);
Assert.assertEquals(100, agentCountStatisticses.size());
long currentTime = System.currentTimeMillis();
range = new Range(currentTime, currentTime + 100);
agentCountStatisticses = dao.selectAgentCount(range);
Assert.assertEquals(0, agentCountStatisticses.size());
}
use of com.navercorp.pinpoint.web.vo.Range in project pinpoint by naver.
the class HeapUsageRateCheckerTest method before.
@BeforeClass
public static void before() {
jvmGcDao = new AgentStatDao<JvmGcBo>() {
@Override
public List<JvmGcBo> getAgentStatList(String agentId, Range range) {
List<JvmGcBo> jvmGcs = new LinkedList<>();
for (int i = 0; i < 36; i++) {
JvmGcBo jvmGcBo = new JvmGcBo();
jvmGcBo.setHeapUsed(70L);
jvmGcBo.setHeapMax(100L);
jvmGcs.add(jvmGcBo);
}
return jvmGcs;
}
@Override
public boolean agentStatExists(String agentId, Range range) {
return true;
}
};
cpuLoadDao = new AgentStatDao<CpuLoadBo>() {
@Override
public List<CpuLoadBo> getAgentStatList(String agentId, Range range) {
return Collections.emptyList();
}
@Override
public boolean agentStatExists(String agentId, Range range) {
return false;
}
};
applicationIndexDao = new ApplicationIndexDao() {
@Override
public List<Application> selectAllApplicationNames() {
throw new UnsupportedOperationException();
}
@Override
public List<String> selectAgentIds(String applicationName) {
if (SERVICE_NAME.equals(applicationName)) {
List<String> agentIds = new LinkedList<String>();
agentIds.add("local_tomcat");
return agentIds;
}
throw new IllegalArgumentException();
}
@Override
public void deleteApplicationName(String applicationName) {
throw new UnsupportedOperationException();
}
@Override
public void deleteAgentIds(Map<String, List<String>> applicationAgentIdMap) {
throw new UnsupportedOperationException();
}
@Override
public void deleteAgentId(String applicationName, String agentId) {
throw new UnsupportedOperationException();
}
};
}
use of com.navercorp.pinpoint.web.vo.Range in project pinpoint by naver.
the class LinkCallDataTest method addCallData.
@Test
public void addCallData() {
LinkKey key = new LinkKey("fromApplication", ServiceType.STAND_ALONE, "toApplication", ServiceType.STAND_ALONE);
long currentTime = System.currentTimeMillis();
LinkCallData data1 = new LinkCallData(key);
data1.addCallData(currentTime, (short) 100, 1L);
data1.addCallData(currentTime + ONE_MINUTE, (short) 100, 1L);
data1.addCallData(currentTime + ONE_MINUTE + ONE_MINUTE, (short) 100, 1L);
data1.addCallData(currentTime + ONE_MINUTE + ONE_MINUTE + ONE_MINUTE, (short) 100, 1L);
data1.addCallData(currentTime + ONE_MINUTE + ONE_MINUTE + ONE_MINUTE + ONE_MINUTE, (short) 100, 1L);
logger.debug("{}", data1.getTimeHistogram().size());
Range range = new Range(currentTime, currentTime + SIX_HOURS);
TimeWindow window = new TimeWindow(range, TimeWindowDownSampler.SAMPLER);
LinkCallData data2 = new LinkCallData(key, window);
data2.addCallData(currentTime, (short) 100, 1L);
data2.addCallData(currentTime + ONE_MINUTE, (short) 100, 1L);
data2.addCallData(currentTime + ONE_MINUTE + ONE_MINUTE, (short) 100, 1L);
data2.addCallData(currentTime + ONE_MINUTE + ONE_MINUTE + ONE_MINUTE, (short) 100, 1L);
data2.addCallData(currentTime + ONE_MINUTE + ONE_MINUTE + ONE_MINUTE + ONE_MINUTE, (short) 100, 1L);
logger.debug("{}", data2.getTimeHistogram().size());
}
Aggregations