- counters added in order to count the cache hit number and the statistical manager computation number, the cache query sampling hit number and the statistical manager query sampling computation number to perform statistics about the effectiveness of the cache.

git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/portlets/user/databases-manager-portlet@100960 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
Loredana Liccardo 2014-10-24 12:16:09 +00:00
parent b6d00aaabc
commit 695e8c423e
1 changed files with 58 additions and 7 deletions

View File

@ -95,6 +95,12 @@ public class GWTdbManagerServiceImpl extends RemoteServiceServlet implements
private static ConcurrentLinkedQueue<DataExchangedThroughQueue> queue = new ConcurrentLinkedQueue<DataExchangedThroughQueue>(); private static ConcurrentLinkedQueue<DataExchangedThroughQueue> queue = new ConcurrentLinkedQueue<DataExchangedThroughQueue>();
private static ThreadDataLoader dataLoader; private static ThreadDataLoader dataLoader;
private static int smComputationNumber;
private static int cacheHitsNumber;
private static int smComputationQuerySamplingNumber;
private static int cacheQuerySamplingHitsNumber;
public GWTdbManagerServiceImpl() throws Exception { public GWTdbManagerServiceImpl() throws Exception {
} }
@ -159,6 +165,13 @@ public class GWTdbManagerServiceImpl extends RemoteServiceServlet implements
// create the thread DataLoader // create the thread DataLoader
dataLoader = new ThreadDataLoader(); dataLoader = new ThreadDataLoader();
logger.info("dbmanager-> Thread Dataloader created"); logger.info("dbmanager-> Thread Dataloader created");
smComputationNumber = 0;
cacheHitsNumber = 0;
smComputationQuerySamplingNumber = 0;
cacheQuerySamplingHitsNumber = 0;
} catch (Exception e) { } catch (Exception e) {
logger.error("dbmanager-> ", e); logger.error("dbmanager-> ", e);
@ -287,6 +300,11 @@ public class GWTdbManagerServiceImpl extends RemoteServiceServlet implements
session.setAttribute("listKeySubmitQueryResult", session.setAttribute("listKeySubmitQueryResult",
listKeySubmitQueryResult); listKeySubmitQueryResult);
//print data
logger.info("dbmanager-> CheckInformation: cache hits number " + cacheHitsNumber);
logger.info("dbmanager-> CheckInformation: SM computation number " + smComputationNumber);
logger.info("dbmanager-> CheckInformation: cache Query Sampling hits number " + cacheQuerySamplingHitsNumber);
logger.info("dbmanager-> CheckInformation: SM Query Sampling computation number " + smComputationQuerySamplingNumber);
} }
// to get resources from IS // to get resources from IS
@ -629,6 +647,9 @@ public class GWTdbManagerServiceImpl extends RemoteServiceServlet implements
if ((data != null) && (submitQueryResult != null)) { if ((data != null) && (submitQueryResult != null)) {
result = (SubmitQueryResultWithFileFromServlet) data; result = (SubmitQueryResultWithFileFromServlet) data;
cacheHitsNumber++;
logger.info("dbmanager-> CheckDataInCache: data found in cache. cacheHitsNumber: " + cacheHitsNumber);
cacheQuerySamplingHitsNumber++;
// set variable to true value if cached data are used and a // set variable to true value if cached data are used and a
// computation is not started // computation is not started
Boolean val = new Boolean(true); Boolean val = new Boolean(true);
@ -636,6 +657,10 @@ public class GWTdbManagerServiceImpl extends RemoteServiceServlet implements
} else { } else {
smComputationNumber++;
logger.info("dbmanager-> CheckDataInCache: data not found in cache. Starting the Statistical Computation. smComputationNumber: " + smComputationNumber);
smComputationQuerySamplingNumber++;
// set variable to false value if cached data are not used and a // set variable to false value if cached data are not used and a
// computation is started // computation is started
Boolean val = new Boolean(false); Boolean val = new Boolean(false);
@ -648,6 +673,7 @@ public class GWTdbManagerServiceImpl extends RemoteServiceServlet implements
String computationId = startComputation(algorithmId, String computationId = startComputation(algorithmId,
inputParameters, outputData, scope, UID); inputParameters, outputData, scope, UID);
// get JobID // get JobID
if (checkJob(UID)) { // if the computation has not been removed if (checkJob(UID)) { // if the computation has not been removed
// the job uid is present // the job uid is present
@ -858,11 +884,16 @@ public class GWTdbManagerServiceImpl extends RemoteServiceServlet implements
} }
if (value != null) { if (value != null) {
result = (SamplingResultWithFileFromServlet) value; result = (SamplingResultWithFileFromServlet) value;
cacheHitsNumber++;
logger.info("dbmanager-> CheckDataInCache: data found in cache. cacheHitsNumber: " + cacheHitsNumber);
cacheQuerySamplingHitsNumber++;
} else { } else {
smComputationNumber++;
logger.info("dbmanager-> CheckDataInCache: data not found in cache. Starting the Statistical Computation. smComputationNumber: " + smComputationNumber);
smComputationQuerySamplingNumber++;
// start computation // start computation
// create data structure // create data structure
ComputationOutput outputData = new ComputationOutput(); ComputationOutput outputData = new ComputationOutput();
// computation id // computation id
@ -1012,9 +1043,13 @@ public class GWTdbManagerServiceImpl extends RemoteServiceServlet implements
} }
if (value != null) { if (value != null) {
result = (SamplingResultWithFileFromServlet) value; result = (SamplingResultWithFileFromServlet) value;
cacheHitsNumber++;
logger.info("dbmanager-> CheckDataInCache: data found in cache. cacheHitsNumber: " + cacheHitsNumber);
cacheQuerySamplingHitsNumber++;
} else { } else {
smComputationNumber++;
logger.info("dbmanager-> CheckDataInCache: data not found in cache. Starting the Statistical Computation. smComputationNumber: " + smComputationNumber);
smComputationQuerySamplingNumber++;
// create data structure // create data structure
ComputationOutput outputData = new ComputationOutput(); ComputationOutput outputData = new ComputationOutput();
// computation id // computation id
@ -2490,7 +2525,12 @@ public class GWTdbManagerServiceImpl extends RemoteServiceServlet implements
if (value != null) { if (value != null) {
// System.out.println("***GETTING DATA FROM CACHE"); // System.out.println("***GETTING DATA FROM CACHE");
outputParameters = (List<FileModel>) value; outputParameters = (List<FileModel>) value;
cacheHitsNumber++;
logger.info("dbmanager-> CheckDataInCache: data found in cache. cacheHitsNumber: " + cacheHitsNumber);
} else { } else {
smComputationNumber++;
logger.info("dbmanager-> CheckDataInCache: data not found in cache. Starting the Statistical Computation. smComputationNumber: " + smComputationNumber);
// start the computation // start the computation
// System.out.println("***STARTING THE COMPUTATION"); // System.out.println("***STARTING THE COMPUTATION");
@ -2571,9 +2611,12 @@ public class GWTdbManagerServiceImpl extends RemoteServiceServlet implements
} }
if (value != null) { if (value != null) {
outputParameters = (LinkedHashMap<String, FileModel>) value; outputParameters = (LinkedHashMap<String, FileModel>) value;
cacheHitsNumber++;
logger.info("dbmanager-> CheckDataInCache: data found in cache. cacheHitsNumber: " + cacheHitsNumber);
// System.out.println("***GETTING DATA FROM CACHE"); // System.out.println("***GETTING DATA FROM CACHE");
} else { } else {
smComputationNumber++;
logger.info("dbmanager-> CheckDataInCache: data not found in cache. Starting the Statistical Computation. smComputationNumber: " + smComputationNumber);
// start the computation // start the computation
// System.out.println("***STARTING THE COMPUTATION"); // System.out.println("***STARTING THE COMPUTATION");
// create data structure // create data structure
@ -2683,7 +2726,11 @@ public class GWTdbManagerServiceImpl extends RemoteServiceServlet implements
} }
if (value != null) { if (value != null) {
outputParameters = (List<FileModel>) value; outputParameters = (List<FileModel>) value;
cacheHitsNumber++;
logger.info("dbmanager-> CheckDataInCache: data found in cache. cacheHitsNumber: " + cacheHitsNumber);
} else { } else {
smComputationNumber++;
logger.info("dbmanager-> CheckDataInCache: data not found in cache. Starting the Statistical Computation. smComputationNumber: " + smComputationNumber);
// start the computation // start the computation
// create data structure // create data structure
@ -2808,9 +2855,13 @@ public class GWTdbManagerServiceImpl extends RemoteServiceServlet implements
} }
if (value != null) { if (value != null) {
outputParameters = (List<Result>) value; outputParameters = (List<Result>) value;
cacheHitsNumber++;
logger.info("dbmanager-> CheckDataInCache: data found in cache. cacheHitsNumber: " + cacheHitsNumber);
} else { } else {
smComputationNumber++;
logger.info("dbmanager-> CheckDataInCache: data not found in cache. Starting the Statistical Computation. smComputationNumber: " + smComputationNumber);
// start computation // start computation
// create data structure // create data structure
ComputationOutput outputData = new ComputationOutput(); ComputationOutput outputData = new ComputationOutput();