/**
* diqube: Distributed Query Base.
*
* Copyright (C) 2015 Bastian Gloeckle
*
* This file is part of diqube.
*
* diqube is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* 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 Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package org.diqube.ui.websocket.result;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.diqube.build.mojo.TypeScriptProperty;
import org.diqube.remote.query.thrift.RQueryStatistics;
import org.diqube.remote.query.thrift.RQueryStatisticsDetails;
import com.fasterxml.jackson.annotation.JsonProperty;
/**
* A simple {@link JsonResult} containing information about statistics of a query.
*
* @author Bastian Gloeckle
*/
@JsonResultDataType(StatsJsonResult.TYPE)
public class StatsJsonResult implements JsonResult {
@TypeScriptProperty
public static final String TYPE = "stats";
@JsonProperty
@TypeScriptProperty
public List<String> nodeNames = new ArrayList<>();
@JsonProperty
@TypeScriptProperty
private List<Long> startedUntilDoneMs = new ArrayList<>();
@JsonProperty
@TypeScriptProperty
private List<Integer> numberOfThreads = new ArrayList<>();
@JsonProperty
@TypeScriptProperty
private List<Integer> numberOfTemporaryColumnShardsCreated = new ArrayList<>();
@JsonProperty
@TypeScriptProperty
private List<Integer> numberOfTemporaryColumnShardsFromCache = new ArrayList<>();
@JsonProperty
@TypeScriptProperty
private Map<String, List<Long>> stepsActiveMs = new HashMap<>();
@JsonProperty
@TypeScriptProperty
private Map<String, List<Integer>> numberOfPageAccesses = new HashMap<>();
@JsonProperty
@TypeScriptProperty
private Map<String, List<Integer>> numberOfTemporaryPageAccesses = new HashMap<>();
@JsonProperty
@TypeScriptProperty
private List<Integer> numberOfPagesInTable = new ArrayList<>();
@JsonProperty
@TypeScriptProperty
private List<Integer> numberOfTemporaryPages = new ArrayList<>();
@JsonProperty
@TypeScriptProperty
private Map<String, List<Integer>> numberOfTemporaryVersionsPerColName = new HashMap<>();
public void loadFromQueryStatRes(RQueryStatistics stats) {
List<RQueryStatisticsDetails> allDetails = new ArrayList<>(Arrays.asList(stats.getMaster()));
allDetails.addAll(stats.getRemotes());
for (RQueryStatisticsDetails detail : allDetails) {
for (String stepName : detail.getStepsActiveMs().keySet())
stepsActiveMs.put(stepName, new ArrayList<>());
for (String pageName : detail.getNumberOfPageAccesses().keySet())
numberOfPageAccesses.put(pageName, new ArrayList<>());
for (String tempPageName : detail.getNumberOfTemporaryPageAccesses().keySet())
numberOfTemporaryPageAccesses.put(tempPageName, new ArrayList<>());
for (String tempColName : detail.getNumberOfTemporaryVersionsPerColName().keySet())
numberOfTemporaryVersionsPerColName.put(tempColName, new ArrayList<>());
}
boolean first = true;
for (RQueryStatisticsDetails detail : allDetails) {
if (first)
nodeNames.add(detail.getNode() + " (master)");
else
nodeNames.add(detail.getNode());
first = false;
startedUntilDoneMs.add(detail.getStartedUntilDoneMs());
numberOfThreads.add(detail.getNumberOfThreads());
numberOfTemporaryColumnShardsCreated.add(detail.getNumberOfTemporaryColumnShardsCreated());
numberOfTemporaryColumnShardsFromCache.add(detail.getNumberOfTemporaryColumnShardsFromCache());
numberOfPagesInTable.add(detail.getNumberOfPagesInTable());
numberOfTemporaryPages.add(detail.getNumberOfTemporaryPages());
for (String stepName : stepsActiveMs.keySet())
stepsActiveMs.get(stepName).add(detail.getStepsActiveMs().get(stepName)); // could be null.
for (String pageName : numberOfPageAccesses.keySet())
numberOfPageAccesses.get(pageName).add(detail.getNumberOfPageAccesses().get(pageName)); // could be null.
for (String tempPageName : numberOfTemporaryPageAccesses.keySet())
numberOfTemporaryPageAccesses.get(tempPageName)
.add(detail.getNumberOfTemporaryPageAccesses().get(tempPageName)); // could be null.
for (String tempColName : numberOfTemporaryVersionsPerColName.keySet())
numberOfTemporaryVersionsPerColName.get(tempColName)
.add(detail.getNumberOfTemporaryVersionsPerColName().get(tempColName)); // could be null.
}
}
}