當前位置: 首頁>>代碼示例>>Java>>正文


Java RemovalNotification.wasEvicted方法代碼示例

本文整理匯總了Java中com.google.common.cache.RemovalNotification.wasEvicted方法的典型用法代碼示例。如果您正苦於以下問題:Java RemovalNotification.wasEvicted方法的具體用法?Java RemovalNotification.wasEvicted怎麽用?Java RemovalNotification.wasEvicted使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在com.google.common.cache.RemovalNotification的用法示例。


在下文中一共展示了RemovalNotification.wasEvicted方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: onRemoval

import com.google.common.cache.RemovalNotification; //導入方法依賴的package包/類
@Override
	public void onRemoval(RemovalNotification<Writable, T> note) {
//		System.err.println("S0 Cache: " + activeKey + " " + note.getKey() + " " + note.getCause() + " " + cache.size());
		if (!(note.wasEvicted() || note.getCause() == RemovalCause.EXPLICIT)) {
			return;
		}
		if (activeKey != null && activeKey.equals(note.getKey())) {
			return;
		}

		try {
//			System.err.println("  s0emit: " + note.getCause() + " " + note.getKey() + " " + note.getValue());
			// Emit the record.
			collector.emit(new FValues(note.getKey(), note.getValue()));
		} catch (Throwable e) {
			lastThrown = e;
		}
	}
 
開發者ID:JamesLampton,項目名稱:piggybank-squeal,代碼行數:19,代碼來源:Stage0Executor.java

示例2: onRemoval

import com.google.common.cache.RemovalNotification; //導入方法依賴的package包/類
public void onRemoval(RemovalNotification<String, List<Tuple>> removal) {
    if (!removal.wasEvicted())
        return;
    LOG.error("Purged from waitAck {} with {} values", removal.getKey(),
            removal.getValue().size());
    for (Tuple t : removal.getValue()) {
        _collector.fail(t);
    }
}
 
開發者ID:eorliac,項目名稱:patent-crawler,代碼行數:10,代碼來源:StatusUpdaterBolt.java

示例3: onRemoval

import com.google.common.cache.RemovalNotification; //導入方法依賴的package包/類
@Override
public void onRemoval(RemovalNotification<IndicesRequestCache.Key, IndicesRequestCache.Value> removalNotification) {
    if (removalNotification.wasEvicted()) {
        evictionsMetric.inc();
    }
    long dec = 0;
    if (removalNotification.getKey() != null) {
        dec += removalNotification.getKey().ramBytesUsed();
    }
    if (removalNotification.getValue() != null) {
        dec += removalNotification.getValue().ramBytesUsed();
    }
    totalMetric.dec(dec);
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:15,代碼來源:ShardRequestCache.java

示例4: onRemoval

import com.google.common.cache.RemovalNotification; //導入方法依賴的package包/類
@Override
public void onRemoval(RemovalNotification<Integer, SettableFuture<CompletedBatchOperation>> notification) {
    // wrapping in ExecutionException to support Future.get
    if (notification.wasEvicted()) {
        notification.getValue()
                .setException(new ExecutionException("Timed out",
                                                     new TimeoutException()));
    }
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:10,代碼來源:SimpleFlowRuleStore.java

示例5: stateRemoved

import com.google.common.cache.RemovalNotification; //導入方法依賴的package包/類
private void stateRemoved(final RemovalNotification<Identifier, AssembledMessageState> notification) {
    if (notification.wasEvicted()) {
        LOG.warn("{}: AssembledMessageState for {} was expired from the cache", logContext, notification.getKey());
    } else {
        LOG.debug("{}: AssembledMessageState for {} was removed from the cache due to {}", logContext,
                notification.getKey(), notification.getCause());
    }

    notification.getValue().close();
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:11,代碼來源:MessageAssembler.java

示例6: stateRemoved

import com.google.common.cache.RemovalNotification; //導入方法依賴的package包/類
private void stateRemoved(final RemovalNotification<Identifier, SlicedMessageState<ActorRef>> notification) {
    final SlicedMessageState<ActorRef> state = notification.getValue();
    state.close();
    if (notification.wasEvicted()) {
        LOG.warn("{}: SlicedMessageState for {} was expired from the cache", logContext, notification.getKey());
        state.getOnFailureCallback().accept(new RuntimeException(String.format(
                "The slicing state for message identifier %s was expired due to inactivity from the assembling "
                 + "component on the other end", state.getIdentifier())));
    } else {
        LOG.debug("{}: SlicedMessageState for {} was removed from the cache due to {}", logContext,
                notification.getKey(), notification.getCause());
    }
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:14,代碼來源:MessageSlicer.java

示例7: SingleSizeCache

import com.google.common.cache.RemovalNotification; //導入方法依賴的package包/類
/**
 * Default constructor. Specify the size of the blocks, number of blocks, and
 * the SlabCache this cache will be assigned to.
 *
 *
 * @param blockSize the size of each block, in bytes
 *
 * @param numBlocks the number of blocks of blockSize this cache will hold.
 *
 * @param master the SlabCache this SingleSlabCache is assigned to.
 */
public SingleSizeCache(int blockSize, int numBlocks,
    SlabItemActionWatcher master) {
  this.blockSize = blockSize;
  this.numBlocks = numBlocks;
  backingStore = new Slab(blockSize, numBlocks);
  this.stats = new CacheStats();
  this.actionWatcher = master;
  this.size = new AtomicLong(CACHE_FIXED_OVERHEAD + backingStore.heapSize());
  this.timeSinceLastAccess = new AtomicLong();

  // This evictionListener is called whenever the cache automatically
  // evicts
  // something.
  RemovalListener<BlockCacheKey, CacheablePair> listener =
    new RemovalListener<BlockCacheKey, CacheablePair>() {
      @Override
      public void onRemoval(
          RemovalNotification<BlockCacheKey, CacheablePair> notification) {
        if (!notification.wasEvicted()) {
          // Only process removals by eviction, not by replacement or
          // explicit removal
          return;
        }
        CacheablePair value = notification.getValue();
        timeSinceLastAccess.set(System.nanoTime()
            - value.recentlyAccessed.get());
        stats.evict();
        doEviction(notification.getKey(), value);
      }
    };

  backingMap = CacheBuilder.newBuilder()
      .maximumSize(numBlocks - 1)
      .removalListener(listener)
      .<BlockCacheKey, CacheablePair>build()
      .asMap();


}
 
開發者ID:fengchen8086,項目名稱:LCIndex-HBase-0.94.16,代碼行數:51,代碼來源:SingleSizeCache.java

示例8: onRemoval

import com.google.common.cache.RemovalNotification; //導入方法依賴的package包/類
@Override
public void onRemoval(RemovalNotification<Integer, SettableFuture<CompletedBatchOperation>> notification) {
    // wrapping in ExecutionException to support Future.get
    if (notification.wasEvicted()) {
        notification.getValue()
            .setException(new ExecutionException("Timed out",
                                             new TimeoutException()));
    }
}
 
開發者ID:ravikumaran2015,項目名稱:ravikumaran201504,代碼行數:10,代碼來源:SimpleFlowRuleStore.java

示例9: SingleSizeCache

import com.google.common.cache.RemovalNotification; //導入方法依賴的package包/類
/**
 * Default constructor. Specify the size of the blocks, number of blocks, and
 * the SlabCache this cache will be assigned to.
 *
 *
 * @param blockSize the size of each block, in bytes
 *
 * @param numBlocks the number of blocks of blockSize this cache will hold.
 *
 * @param master the SlabCache this SingleSlabCache is assigned to.
 */
public SingleSizeCache(int blockSize, int numBlocks,
    SlabItemActionWatcher master) {
  this.blockSize = blockSize;
  this.numBlocks = numBlocks;
  backingStore = new Slab(blockSize, numBlocks);
  this.stats = new CacheStats();
  this.actionWatcher = master;
  this.size = new AtomicLong(CACHE_FIXED_OVERHEAD + backingStore.heapSize());
  this.timeSinceLastAccess = new AtomicLong();

  // This evictionListener is called whenever the cache automatically
  // evicts something.
  RemovalListener<BlockCacheKey, CacheablePair> listener =
    new RemovalListener<BlockCacheKey, CacheablePair>() {
      @Override
      public void onRemoval(
          RemovalNotification<BlockCacheKey, CacheablePair> notification) {
        if (!notification.wasEvicted()) {
          // Only process removals by eviction, not by replacement or
          // explicit removal
          return;
        }
        CacheablePair value = notification.getValue();
        timeSinceLastAccess.set(System.nanoTime()
            - value.recentlyAccessed.get());
        stats.evict();
        doEviction(notification.getKey(), value);
      }
    };

  backingMap = CacheBuilder.newBuilder()
      .maximumSize(numBlocks - 1)
      .removalListener(listener)
      .<BlockCacheKey, CacheablePair>build()
      .asMap();
}
 
開發者ID:tenggyut,項目名稱:HIndex,代碼行數:48,代碼來源:SingleSizeCache.java

示例10: onRemoval

import com.google.common.cache.RemovalNotification; //導入方法依賴的package包/類
@Override
public void onRemoval(
        RemovalNotification<Integer, SettableFuture<Response>> arg0) {
    if (arg0.wasEvicted()) {
        SettableFuture<Response> response = arg0.getValue();
        logger.warn("request id {} timeout", arg0.getKey());
        response.setException(new RequestTimeoutException("request timeout"));
    }
}
 
開發者ID:lyogavin,項目名稱:Pistachio,代碼行數:10,代碼來源:NettyPistachioClientHandler.java

示例11: onRemoval

import com.google.common.cache.RemovalNotification; //導入方法依賴的package包/類
@Override
	public void onRemoval(RemovalNotification<Writable, T> note) {
//		System.err.println("S1 Cache: " + activeKey + " " + note.getKey() + " " + note.getCause() + " " + cache.size());
		if (!(note.wasEvicted() || note.getCause() == RemovalCause.EXPLICIT)) {
			return;
		}
		
		if (activeKey != null && activeKey.equals(note.getKey())) {
			return;
		}

		try {
			// Determine if the current value is in the backlog or the prefetch.
			T cur;
			if (!stateBacklog.containsKey(note.getKey())) {
				// Pull the values in from the prefetch.
				runPrefetch();
			}
			cur = stateBacklog.remove(note.getKey());
//			System.err.println("stateBacklogged: k=<" + note.getKey() + "> v=" + cur);

			// Apply the update.
			cur = storeAgg.combine(cur, note.getValue());

			// Move things to the writeAhead.
			writeAhead.put(note.getKey(), cur);

			// Emit the result.
			collector.emit(new FValues(note.getKey(), cur));
		} catch (Throwable e) {
			lastThrown = e;
		}
	}
 
開發者ID:JamesLampton,項目名稱:piggybank-squeal,代碼行數:34,代碼來源:Stage1Executor.java

示例12: onRemoval

import com.google.common.cache.RemovalNotification; //導入方法依賴的package包/類
@Override
public void onRemoval(RemovalNotification<IpmiReceiverKey, IpmiReceiver> notification) {
    IpmiReceiverKey key = notification.getKey();
    IpmiReceiver receiver = notification.getValue();
    if (key != null && receiver != null && notification.wasEvicted())
        receiver.timeout(key);
}
 
開發者ID:shevek,項目名稱:ipmi4j,代碼行數:8,代碼來源:IpmiPayloadReceiveDispatcher.java

示例13: onRemoval

import com.google.common.cache.RemovalNotification; //導入方法依賴的package包/類
@Override
public void onRemoval(RemovalNotification<Integer,
        SettableFuture<CompletedBatchOperation>> notification) {
    // wrapping in ExecutionException to support Future.get
    if (notification.wasEvicted()) {
        notification.getValue()
                .setException(new ExecutionException("Timed out",
                                                     new TimeoutException()));
    }
}
 
開發者ID:opennetworkinglab,項目名稱:onos,代碼行數:11,代碼來源:SimpleVirtualFlowRuleStore.java

示例14: onRemoval

import com.google.common.cache.RemovalNotification; //導入方法依賴的package包/類
@Override
public void onRemoval(RemovalNotification<Long, Callback> entry) {
    if (entry.wasEvicted()) {
        entry.getValue().completeExceptionally(new TimeoutException("Timedout waiting for reply"));
    }
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:7,代碼來源:NettyMessagingManager.java

示例15: onRemoval

import com.google.common.cache.RemovalNotification; //導入方法依賴的package包/類
@Override
public void onRemoval(RemovalNotification<Long, SettableFuture<byte[]>> entry) {
    if (entry.wasEvicted()) {
        entry.getValue().setException(new TimeoutException("Timedout waiting for reply"));
    }
}
 
開發者ID:ravikumaran2015,項目名稱:ravikumaran201504,代碼行數:7,代碼來源:NettyMessagingService.java


注:本文中的com.google.common.cache.RemovalNotification.wasEvicted方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。