guava缓存

private LoadingCache<Integer, List<Long>> topAdvertListCache = CacheBuilder.newBuilder()
            .maximumSize(1000)
            .refreshAfterWrite(60, TimeUnit.SECONDS)
            .build(
                    new CacheLoader<Integer, List<Long>>() {
                        public List<Long> load(Integer key) {
                            return getTopAdvertFromEs(key);
                        }


                        public ListenableFutureTask<List<Long>> reload(final Integer key, List<Long> prevGraph) {
                            ListenableFutureTask<List<Long>> task = ListenableFutureTask.create(() -> getTopAdvertFromEs(key));
                            Executors.newSingleThreadExecutor().execute(task);
                            return task;
                        }
                    });


    private List<Long> getTopAdvertFromEs(Integer key) {
        SearchQuery searchQuery = new NativeSearchQueryBuilder()
                .withQuery(matchAllQuery())
                .withSearchType(SearchType.DEFAULT)
                .withIndices(couponLogEsConfig.getIndexPrefix() + "-" + getYesterdayDate()).withTypes(couponLogEsConfig.getTypeName())
                .addAggregation(terms("AppId").field("appId").size(0))
                .build();
        Aggregations aggregations = esTemplate.query(searchQuery, response -> response.getAggregations());
        Terms byApp = aggregations.get("AppId");
        Map<Long, Long> newMap = new TreeMap(Collections.reverseOrder());
        for (Terms.Bucket entry : byApp.getBuckets()) {
            newMap.put(entry.getDocCount(), Long.parseLong(entry.getKey().toString()));
        }
        return newMap.values().stream().limit(key).collect(Collectors.toList());

    }


 private List<Long> buildTopAdvIds(ReqAdvertFlowEstimate reqAdvertFlowEstimate) {
        List<Long> topAdvertList = topAdvertListCache.getUnchecked(TOPADV_COUNT);
        logger.info("TOPADVETIDS:"+JSON.toJSONString(topAdvertList)+"BINDAPP:"+JSON.toJSONString(reqAdvertFlowEstimate.getBindApp()));
        if (reqAdvertFlowEstimate.getBindApp() != null&&reqAdvertFlowEstimate.getBindApp().size()>0) {//过滤定向APP的广告列表
            topAdvertList = topAdvertList.stream().filter(x -> reqAdvertFlowEstimate.getBindApp().contains(Integer.parseInt(x.toString()))).collect(Collectors.toList());
        }
        return topAdvertList;
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值