zoukankan      html  css  js  c++  java
  • GuaVa缓存应用

    LoadingCache<String, List<Order>> cacheOrders = CacheBuilder.newBuilder()
    .expireAfterWrite(1, TimeUnit.MINUTES)//表示在写入内存1分钟后该数据过期
    .expireAfterAccess(1, TimeUnit.MINUTES)//表示如果1分钟之内没有使用该缓存则数据过期 每调用一次缓存有效时间都刷新为一分钟
    .refreshAfterWrite(1, TimeUnit.MINUTES)//只阻塞当前数据加载线程,其他线程返回旧值
    .concurrencyLevel(8)//设置并发级别为8,并发级别是指可以同时写缓存的线程数
    .maximumSize(100)//设置最大缓存数 超过限制采用最少使用淘汰机制
    .build(new CacheLoader<String, List<Order>>() {
                /**  当本地缓存命没有中时,调用load方法获取结果并将结果缓存
    */
    @Override
    public List<Order> load(String key) {
    return getOrders();
    }

    // 此时一般我们会进行相关处理,如到数据库去查询
    private List<Order> getOrders() {
    List<Order> orderList = (List<Order>) redisUtil.hmGet(redisTemplate, ControlConstants.RTB_OF_ORDER, ControlConstants.DSP_RTB_AREA_DEAL);
    log.info("缓存失效重新获取订单" + orderList.size());
    return orderList;

    }
    });

    当然,除此之外,缓存还有其他初始化设置,例如设置要统计缓存的命中率等,guava的缓存还可以以异步线程的方式刷新本地的缓存,这里不做详细说明
  • 相关阅读:
    Git Step by Step – (1) Git 简介
    MongoDB的C#驱动基本使用
    MongoDB的数据模型
    MongoDB管理
    MongoDB分片
    MongoDB副本集的工作原理
    MongoDB副本集
    MongoDB聚合管道
    Python 16 html 基础 jQuery & Javascript研究
    Python 15 html 基础
  • 原文地址:https://www.cnblogs.com/xiaohan666/p/10901118.html
Copyright © 2011-2022 走看看