当前位置: 首页>>代码示例>>Java>>正文


Java Deferred.addCallback方法代码示例

本文整理汇总了Java中com.stumbleupon.async.Deferred.addCallback方法的典型用法代码示例。如果您正苦于以下问题:Java Deferred.addCallback方法的具体用法?Java Deferred.addCallback怎么用?Java Deferred.addCallback使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在com.stumbleupon.async.Deferred的用法示例。


在下文中一共展示了Deferred.addCallback方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: persist

import com.stumbleupon.async.Deferred; //导入方法依赖的package包/类
@Override
public void persist(String metric, DataPoint dp, Map<String, String> tags, final Function<Object, Void> callback) {
    try {
        if(callback == null) {
            tsdb.addPoint(metric, dp.getTimestamp(), dp.getValue(), tags).joinUninterruptibly();
        }
        else {

            Deferred<Object> ret = tsdb.addPoint(metric, dp.getTimestamp(), dp.getValue(), tags);
            ret.addCallback(new Callback<Object, Object>() {
                @Override
                public Object call(Object o) throws Exception {
                    return callback.apply(o);
                }
            });
        }
    } catch (Exception e) {
        throw new RuntimeException(e.getMessage(), e);
    }
}
 
开发者ID:cestella,项目名称:streaming_outliers,代码行数:21,代码来源:TSDBHandler.java

示例2: writeDataPoints

import com.stumbleupon.async.Deferred; //导入方法依赖的package包/类
/**
 * Main entry method for adding points
 *
 * @param data points list
 */
private void writeDataPoints(List<EventData> data) throws Exception {
  if (data.size() < 1)
    return;
  final WritableDataPoints dataPoints = tsdb.newDataPoints();
  final EventData first = data.get(0);
  dataPoints.setSeries(first.metric, first.tags);
  dataPoints.setBatchImport(false); // we need data to be persisted
  long prevTs = 0;
  Set<String> failures = new HashSet<String>();
  for (EventData eventData : data) {
    try {
      if (eventData.timestamp == prevTs)
        continue;
      sinkCounter.incrementEventDrainAttemptCount();
      prevTs = eventData.timestamp;
      final Deferred<Object> d =
              eventData.makeDeferred(dataPoints, this);
      d.addCallback(new Callback<Object, Object>() {
        @Override
        public Object call(Object o) throws Exception {
          pointsCounter.mark();
          inFlight.decrementAndGet();
          signal.release();
          return null;
        }
      });
      d.addErrback(this);
      if (throttle)
        throttle(d);
      inFlight.incrementAndGet();
      sinkCounter.incrementEventDrainSuccessCount();
    } catch (IllegalArgumentException ie) {
      failures.add(ie.getMessage());
    }
  }
  if (failures.size() > 0) {
    logger.error("Points imported with " + failures.toString() + " IllegalArgumentExceptions");
  }
}
 
开发者ID:yandex,项目名称:opentsdb-flume,代码行数:45,代码来源:OpenTSDBSink.java


注:本文中的com.stumbleupon.async.Deferred.addCallback方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。