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


Java Caffeine類代碼示例

本文整理匯總了Java中com.github.benmanes.caffeine.cache.Caffeine的典型用法代碼示例。如果您正苦於以下問題:Java Caffeine類的具體用法?Java Caffeine怎麽用?Java Caffeine使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: cacheExposesMetricsForHitMissAndEviction

import com.github.benmanes.caffeine.cache.Caffeine; //導入依賴的package包/類
@Test
void cacheExposesMetricsForHitMissAndEviction() throws Exception {
    // Run cleanup in same thread, to remove async behavior with evictions
    Cache<String, String> cache = Caffeine.newBuilder().maximumSize(2).recordStats().executor(Runnable::run).build();
    CaffeineCacheMetrics.monitor(registry, cache, "c", userTags);

    cache.getIfPresent("user1");
    cache.getIfPresent("user1");
    cache.put("user1", "First User");
    cache.getIfPresent("user1");

    // Add to cache to trigger eviction.
    cache.put("user2", "Second User");
    cache.put("user3", "Third User");
    cache.put("user4", "Fourth User");

    assertThat(registry.mustFind("c.requests").tags("result", "hit").tags(userTags).functionCounter().count()).isEqualTo(1.0);
    assertThat(registry.mustFind("c.requests").tags("result", "miss").tags(userTags).functionCounter().count()).isEqualTo(2.0);
    assertThat(registry.mustFind("c.evictions").tags(userTags).functionCounter().count()).isEqualTo(2.0);
}
 
開發者ID:micrometer-metrics,項目名稱:micrometer,代碼行數:21,代碼來源:CaffeineCacheMetricsTest.java

示例2: start

import com.github.benmanes.caffeine.cache.Caffeine; //導入依賴的package包/類
public void start() {

            if(started) {
                throw new RuntimeException("Already started or in progress");
            }

            started  = true;

            if(service == null) {
                service = newDefaultForkJoinPool(threadsCount);
            }
            cachedDispatchQueues = Caffeine.newBuilder()
                    .weakValues()
                    .executor(service)
                    .maximumSize(queueSize)
                    .build().asMap();

        }
 
開發者ID:vibneiro,項目名稱:dispatching,代碼行數:19,代碼來源:CaffeineCachedDispatcher.java

示例3: filterByStream

import com.github.benmanes.caffeine.cache.Caffeine; //導入依賴的package包/類
@Test
public void filterByStream() throws Exception {
	Cache<String, LinkedList<ApplicationMetrics>> rawCache = Caffeine.newBuilder().build();
	ApplicationMetricsService service = new ApplicationMetricsService(rawCache);
	MetricsAggregator aggregator = new MetricsAggregator(service);
	MetricsCollectorEndpoint endpoint = new MetricsCollectorEndpoint(service);

	ApplicationMetrics app = createMetrics("httpIngest", "http", "foo", 0);
	ApplicationMetrics app1 = createMetrics("httpIngest", "http", "foobar", 1);
	ApplicationMetrics app2 = createMetrics("woodchuck", "time", "bar", 0);
	ApplicationMetrics app3 = createMetrics("twitter", "twitterstream", "bar", 0);

	aggregator.receive(app);
	aggregator.receive(app1);
	aggregator.receive(app2);
	aggregator.receive(app3);

	Assert.assertEquals(2, endpoint.fetchMetrics("httpIngest,woodchuck").getBody().getContent().size());
}
 
開發者ID:spring-cloud,項目名稱:spring-cloud-dataflow-metrics-collector,代碼行數:20,代碼來源:MetricsAggregatorTests.java

示例4: filterUsingInvalidDelimiter

import com.github.benmanes.caffeine.cache.Caffeine; //導入依賴的package包/類
@Test
public void filterUsingInvalidDelimiter() throws Exception {
	Cache<String, LinkedList<ApplicationMetrics>> rawCache = Caffeine.newBuilder().build();
	ApplicationMetricsService service = new ApplicationMetricsService(rawCache);
	MetricsAggregator aggregator = new MetricsAggregator(service);
	MetricsCollectorEndpoint endpoint = new MetricsCollectorEndpoint(service);

	ApplicationMetrics app = createMetrics("httpIngest", "http", "foo", 0);
	ApplicationMetrics app2 = createMetrics("woodchuck", "time", "bar", 0);
	ApplicationMetrics app3 = createMetrics("twitter", "twitterstream", "bar", 0);

	aggregator.receive(app);
	aggregator.receive(app2);
	aggregator.receive(app3);

	Assert.assertEquals(0, endpoint.fetchMetrics("httpIngest;woodchuck").getBody().getContent().size());
}
 
開發者ID:spring-cloud,項目名稱:spring-cloud-dataflow-metrics-collector,代碼行數:18,代碼來源:MetricsAggregatorTests.java

示例5: loadingCacheExposesMetricsForLoadsAndExceptions

import com.github.benmanes.caffeine.cache.Caffeine; //導入依賴的package包/類
@SuppressWarnings("unchecked")
@Test
void loadingCacheExposesMetricsForLoadsAndExceptions() throws Exception {
    LoadingCache<Integer, String> cache = CaffeineCacheMetrics.monitor(registry, Caffeine.newBuilder()
        .recordStats()
        .build(key -> {
            if (key % 2 == 0)
                throw new Exception("no evens!");
            return key.toString();
        }), "c", userTags);

    cache.get(1);
    cache.get(1);
    try {
        cache.get(2); // throws exception
    } catch (Exception ignored) {
    }
    cache.get(3);

    assertThat(registry.mustFind("c.requests").tags("result", "hit").tags(userTags).functionCounter().count()).isEqualTo(1.0);
    assertThat(registry.mustFind("c.requests").tags("result", "miss").tags(userTags).functionCounter().count()).isEqualTo(3.0);
    assertThat(registry.mustFind("c.load").tags("result", "failure").functionCounter().count()).isEqualTo(1.0);
    assertThat(registry.mustFind("c.load").tags("result", "success").functionCounter().count()).isEqualTo(2.0);
}
 
開發者ID:micrometer-metrics,項目名稱:micrometer,代碼行數:25,代碼來源:CaffeineCacheMetricsTest.java

示例6: includeOneMetric

import com.github.benmanes.caffeine.cache.Caffeine; //導入依賴的package包/類
@Test
public void includeOneMetric() throws Exception {
	Long now = System.currentTimeMillis();
	Metric<Double> inputSendCount = new Metric<Double>("integration.channel.input.sendCount",10.0, new Date(now));
	ApplicationMetrics app = createMetrics("httpIngest", "http", "foo",0);
	app.getMetrics().add(inputSendCount);
	Cache<String, LinkedList<ApplicationMetrics>> rawCache = Caffeine.newBuilder().build();
	ApplicationMetricsService service = new ApplicationMetricsService(rawCache);
	MetricsAggregator aggregator = new MetricsAggregator(service);
	MetricsCollectorEndpoint endpoint = new MetricsCollectorEndpoint(service);
	aggregator.receive(app);

	Assert.assertEquals(1, rawCache.estimatedSize());
	StreamMetrics streamMetrics = endpoint.fetchMetrics("").getBody().iterator().next();
	Application application = streamMetrics.getApplications().get(0);
	Assert.assertNotNull(streamMetrics);
	Assert.assertEquals("http", application.getName());
	Instance instance = application.getInstances().get(0);
	Assert.assertEquals(app.getName(),instance.getKey());
	Assert.assertEquals("foo", instance.getGuid());
	Metric<Double> computed = instance.getMetrics().stream().filter(metric -> metric.getName().equals("integration.channel.input.send.mean")).findFirst().get();
	Assert.assertEquals(0, computed.getValue(),0.0);
}
 
開發者ID:spring-cloud,項目名稱:spring-cloud-dataflow-metrics-collector,代碼行數:24,代碼來源:MetricsAggregatorTests.java

示例7: addApplication

import com.github.benmanes.caffeine.cache.Caffeine; //導入依賴的package包/類
@Test
public void addApplication() throws Exception {
	Cache<String, LinkedList<ApplicationMetrics>> rawCache = Caffeine.newBuilder().build();
	ApplicationMetricsService service = new ApplicationMetricsService(rawCache);
	MetricsAggregator aggregator = new MetricsAggregator(service);
	MetricsCollectorEndpoint endpoint = new MetricsCollectorEndpoint(service);


	ApplicationMetrics app = createMetrics("httpIngest", "http", "foo", 0);
	ApplicationMetrics app2 = createMetrics("httpIngest", "log", "bar", 0);

	aggregator.receive(app);
	aggregator.receive(app2);

	Assert.assertEquals(2, rawCache.estimatedSize());
	StreamMetrics streamMetrics = endpoint.fetchMetrics("").getBody().iterator().next();
	Assert.assertEquals(2, streamMetrics.getApplications().size());
}
 
開發者ID:spring-cloud,項目名稱:spring-cloud-dataflow-metrics-collector,代碼行數:19,代碼來源:MetricsAggregatorTests.java

示例8: addStream

import com.github.benmanes.caffeine.cache.Caffeine; //導入依賴的package包/類
@Test
public void addStream() throws Exception {
	Cache<String, LinkedList<ApplicationMetrics>> rawCache = Caffeine.newBuilder().build();
	ApplicationMetricsService service = new ApplicationMetricsService(rawCache);
	MetricsAggregator aggregator = new MetricsAggregator(service);
	MetricsCollectorEndpoint endpoint = new MetricsCollectorEndpoint(service);


	ApplicationMetrics app = createMetrics("httpIngest", "http", "foo", 0);
	ApplicationMetrics app2 = createMetrics("woodchuck", "time", "bar", 0);

	aggregator.receive(app);
	aggregator.receive(app2);

	Assert.assertEquals(2, endpoint.fetchMetrics("").getBody().getContent().size());
}
 
開發者ID:spring-cloud,項目名稱:spring-cloud-dataflow-metrics-collector,代碼行數:17,代碼來源:MetricsAggregatorTests.java

示例9: getCache

import com.github.benmanes.caffeine.cache.Caffeine; //導入依賴的package包/類
public static Cache<String, Authentication> getCache() {
    if (-1 == sessionMaxAge) {
        throw new IllegalStateException("Cache session max age not configured.");
    }
    if (null == CACHE) {
        CACHE = Caffeine.newBuilder().expireAfterAccess(sessionMaxAge, TimeUnit.SECONDS).build();
    }
    return CACHE;
}
 
開發者ID:NationalSecurityAgency,項目名稱:qonduit,代碼行數:10,代碼來源:AuthCache.java

示例10: init

import com.github.benmanes.caffeine.cache.Caffeine; //導入依賴的package包/類
public static synchronized void init(Configuration config) {
    if (CACHE == null) {
        long expireMinutes = config.getVisibilityCache().getExpirationMinutes();
        int initialCapacity = config.getVisibilityCache().getInitialCapacity();
        long maxCapacity = config.getVisibilityCache().getMaxCapacity();
        CACHE = Caffeine.newBuilder().expireAfterAccess(expireMinutes, TimeUnit.MINUTES)
                .initialCapacity(initialCapacity).maximumSize(maxCapacity).build();
    }
}
 
開發者ID:NationalSecurityAgency,項目名稱:qonduit,代碼行數:10,代碼來源:VisibilityCache.java

示例11: CachingGoogleAuthCodeFlow

import com.github.benmanes.caffeine.cache.Caffeine; //導入依賴的package包/類
private CachingGoogleAuthCodeFlow(final int authCacheTtl,
                                  final String clientId,
                                  final String clientSecret,
                                  final String organizationId,
                                  final String redirectUri) throws IOException {
    this.authCache = Caffeine.newBuilder()
            .maximumSize(4096)
            .expireAfterWrite(authCacheTtl, MILLISECONDS)
            .build(k -> this.isOrganizationMember(k, true));
    this.authFlow = new GoogleAuthorizationCodeFlow.Builder(
            HTTP_TRANSPORT,
            JSON_FACTORY,
            clientId,
            clientSecret,
            SCOPES
    ).setDataStoreFactory(
            DATA_STORE_FACTORY
    ).setAccessType(
            "offline"
    ).setApprovalPrompt(
            "force"
    ).build();
    this.organizationId = organizationId;
    this.redirectUri = redirectUri;
}
 
開發者ID:travelaudience,項目名稱:nexus-proxy,代碼行數:26,代碼來源:CachingGoogleAuthCodeFlow.java

示例12: PokeAPI

import com.github.benmanes.caffeine.cache.Caffeine; //導入依賴的package包/類
public PokeAPI(File storageDir) {
    storageDir.mkdirs();
    this.pokemonCache = Caffeine.newBuilder()
            .maximumSize(100)
            .build((k)->{
                File f = new File(storageDir, k + ".pokemon");
                if(f.exists()) {
                    FileInputStream fis = new FileInputStream(f);
                    Pokemon p = Pokemon.load(new DataInputStream(fis));
                    fis.close();
                    return Optional.of(p);
                }
                return Optional.ofNullable(fromJSONObject(f, REQUESTER.newRequest("http://pokeapi.co/api/v2/pokemon/" + k)
                        .header("User-Agent", "Gabriel (Discord bot)")
                        .get()
                        .asObject()
                ));
            });
}
 
開發者ID:natanbc,項目名稱:GabrielBot,代碼行數:20,代碼來源:PokeAPI.java

示例13: ChannelPool

import com.github.benmanes.caffeine.cache.Caffeine; //導入依賴的package包/類
/**
 * <p>Constructor for ChannelPool.</p>
 *
 * @param factory a {@link com.github.ibole.microservice.rpc.client.grpc.ChannelPool.ChannelFactory} object.
 * @param initialCapacity the initial capacity of the channel pool
 * @param maximumSize the maximum size of the channel pool
 * @return the instance of ChannelPool
 * @throws java.io.IOException if any.
 */
private ChannelPool(ChannelFactory factory, int initialCapacity, int maximumSize) {
  Preconditions.checkArgument(factory != null,
      "ChannelFactory cannot be null.");
  Preconditions.checkArgument(initialCapacity > 0,
      "Channel initial capacity has to be a positive number.");
  Preconditions.checkArgument(maximumSize > 0,
      "Channel maximum size has to be a positive number.");
  Preconditions
      .checkArgument(maximumSize >= initialCapacity,
          "The maximum size of channel pool has to be greater than or equal to the initial capacity.");
  
  Caffeine<String, InstrumentedChannel> caffeine = Caffeine.newBuilder().initialCapacity(initialCapacity).maximumSize(maximumSize).weakKeys()
      .softValues().removalListener(new ChannelRemovalListener());
  this.factory = factory;
  channelPool = caffeine.build();
}
 
開發者ID:benson-git,項目名稱:ibole-microservice,代碼行數:26,代碼來源:ChannelPool.java

示例14: init

import com.github.benmanes.caffeine.cache.Caffeine; //導入依賴的package包/類
@PostConstruct
public void init() {
    analyseStatsCache = Caffeine.newBuilder()
            .maximumSize(config.readLong(ConfigProperty.ANALYSIS_STATISTIC_CACHE_SIZE))
            .expireAfterWrite(config.readLong(ConfigProperty.ANALYSIS_STATISTIC_CACHE_SECONDS), TimeUnit.SECONDS)
            .build();
    dispatcher.requireAuth().blocking().filter(c ->
            c.files().size() == 1,
            "You should provide only a single log file.")
            .postUpload("/gc/jvm/log/process", this::processJvmLog);
    dispatcher.blocking().requireAuth().filter(requiredWithPeriod(), periodMessage())
            .get("/gc/jvm/events", this::jvmEvents);
    dispatcher.blocking().requireAuth().filter(requiredWithPeriod(), periodMessage())
            .get("/gc/jvm/events/stream", this::jvmEventsStream);
    dispatcher.blocking().requireAuth().filter(requiredWithPeriod(), periodMessage())
            .get("/gc/jvm/events/full/stream", this::fullJvmEventsStream);
    dispatcher.blocking().requireAuth().filter(requiredWithPeriod(), periodMessage())
            .get("/gc/jvm/events/full/sample/stream", this::fullJvmSampleEventsStream);
    dispatcher.requireAuth().filter(requiredWithPeriod(), periodMessage())
            .get("/gc/jvm/events/erase", this::jvmEventsErase);
    dispatcher.requireAuth().filter(requiredWithoutPeriod(), message())
            .get("/gc/jvm/events/erase/all", this::jvmEventsEraseAll);
    dispatcher.requireAuth().filter(requiredWithPeriod(), message())
            .get("/gc/jvm/events/stats", this::jvmStats);
}
 
開發者ID:dmart28,項目名稱:gcplot,代碼行數:26,代碼來源:EventsController.java

示例15: LRUCache

import com.github.benmanes.caffeine.cache.Caffeine; //導入依賴的package包/類
/**
 * Constructs an empty <tt>LRUCache</tt> instance with the
 * specified initial capacity, maximumCacheSize,load factor and ordering mode.
 *
 * @param initialCapacity  the initial capacity.
 * @param maximumCacheSize the max capacity.
 * @param stopOnEviction   whether to stop service on eviction.
 * @param soft             whether to use soft values a soft cache  (default is false)
 * @param weak             whether to use weak keys/values as a weak cache  (default is false)
 * @param syncListener     whether to use synchronous call for the eviction listener (default is false)
 * @throws IllegalArgumentException if the initial capacity is negative
 */
public LRUCache(int initialCapacity, int maximumCacheSize, boolean stopOnEviction,
                boolean soft, boolean weak, boolean syncListener) {
    Caffeine<K, V> caffeine = Caffeine.newBuilder()
            .initialCapacity(initialCapacity)
            .maximumSize(maximumCacheSize)
            .removalListener(this);
    if (soft) {
        caffeine.softValues();
    }
    if (weak) {
        caffeine.weakKeys();
        caffeine.weakValues();
    }
    if (syncListener) {
        caffeine.executor(Runnable::run);
    }

    this.cache = caffeine.build();
    this.map = cache.asMap();
    this.maxCacheSize = maximumCacheSize;
    this.stopOnEviction = stopOnEviction;
}
 
開發者ID:HydAu,項目名稱:Camel,代碼行數:35,代碼來源:LRUCache.java


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