com.espertech.esper.epl.metric.MetricExecEngine Maven / Gradle / Ivy
/*
***************************************************************************************
* Copyright (C) 2006 EsperTech, Inc. All rights reserved. *
* http://www.espertech.com/esper *
* http://www.espertech.com *
* ---------------------------------------------------------------------------------- *
* The software in this package is published under the terms of the GPL license *
* a copy of which has been included with this distribution in the license.txt file. *
***************************************************************************************
*/
package com.espertech.esper.epl.metric;
import com.espertech.esper.client.metric.EngineMetric;
/**
* Metrics execution producing engine metric events.
*/
public class MetricExecEngine implements MetricExec {
private final MetricEventRouter metricEventRouter;
private final String engineURI;
private final MetricScheduleService metricScheduleService;
private final long interval;
private EngineMetric lastMetric;
/**
* Ctor.
*
* @param metricEventRouter for routing metric events
* @param engineURI engine uri
* @param metricScheduleService for scheduling a new execution
* @param interval for rescheduling the execution
*/
public MetricExecEngine(MetricEventRouter metricEventRouter, String engineURI, MetricScheduleService metricScheduleService, long interval) {
this.metricEventRouter = metricEventRouter;
this.engineURI = engineURI;
this.metricScheduleService = metricScheduleService;
this.interval = interval;
}
public void execute(MetricExecutionContext context) {
long inputCount = context.getServices().getFilterService().getNumEventsEvaluated();
long schedDepth = context.getServices().getSchedulingService().getScheduleHandleCount();
long deltaInputCount = lastMetric == null ? inputCount : inputCount - lastMetric.getInputCount();
EngineMetric metric = new EngineMetric(engineURI, metricScheduleService.getCurrentTime(), inputCount, deltaInputCount, schedDepth);
lastMetric = metric;
metricEventRouter.route(metric);
metricScheduleService.add(interval, this);
}
/**
* Returns reporting interval.
*
* @return reporting interval
*/
public long getInterval() {
return interval;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy