public void registerMetricIfMissing(String metricName, EagleMetric metric) { if (registry.getMetrics().get(metricName) == null) { metric.registerListener(listener); registry.register(metricName, metric); } } @Override
@Override public void flatMap(List<Object> input, Collector<Tuple1<String>> collector) { try { String user = (String) input.get(0); Long timestamp = (Long) input.get(1); String metricKey = generateMetricKey(user); if (registry.getMetrics().get(metricKey) == null) { EagleCounterMetric metric = new EagleCounterMetric(timestamp, metricKey, 1.0, granularity); metric.registerListener(listener); registry.register(metricKey, metric); } else { EagleMetric metric = (EagleMetric)registry.getMetrics().get(metricKey); metric.update(1, timestamp); //TODO: if we need to remove metric from registry } } catch (Exception ex) { LOG.error("Got an exception, ex: ", ex); } } }
@Override public void execute(Tuple input) { try { String user = input.getString(0); Long timestamp = input.getLong(1); String metricKey = generateMetricKey(user); if (registry.getMetrics().get(metricKey) == null) { EagleCounterMetric metric = new EagleCounterMetric(timestamp, metricKey, 1.0, granularity); metric.registerListener(listener); registry.register(metricKey, metric); } else { EagleMetric metric = (EagleMetric)registry.getMetrics().get(metricKey); metric.update(1, timestamp); //TODO: if we need to remove metric from registry } } catch (Exception ex) { LOG.error("Got an exception, ex: ", ex); }finally { collector.ack(input); } } }
public void registerMetricIfMissing(String metricName, EagleMetric metric) { if (registry.getMetrics().get(metricName) == null) { metric.registerListener(listener); registry.register(metricName, metric); } }