缓存击穿后单机只用一个线程命中Db策略

private ConcurrentHashMap<Integer, FutureTask<ShopDto> shopTaskMap = new ConcurrentHashMap<Integer, FutureTask<ShopDto>();

public ShopDto loadShop(int shopId) { 
    ShopDto dto = getFromCache(shopId); 
    if (dto == null) { 
        FutureTask<ShopDto> future = shopTaskMap.get(shopId); 
        if (future == null) { 
            FutureTask<ShopDto> task = new FutureTask<ShopDto>(new ShopDBTask(shopId)); 
            future = shopTaskMap.putIfAbsent(shopId, task); 
            if (future == null) { 
                future = task;
                future.run(); //确保本机只有一个线程命中DB
            }
        }
        try { 
             dto = future.get(200, TimeUnit.MILLISECONDS); 
        } catch (Exception e) { 
              return null; 
        } finally { 
            shopTaskMap.remove(shopId);
        } } //end if (dto == null)
     return dto; 
}
class ShopDBTask implements Callable<ShopDto>{ 
    private int shopId; 
    public ShopDBTask (int shopId){ 
        this.shopId = shopId; 
    }
    @Override
    public ShopDto call() throws Exception { 
         ShopDto dto = loadFromDB(shopId);
         if(dto == null){ 
             dto = new ShopDto (); 
         }
        setCache(shopId, ShopDto); 
         return dto; 
    } }

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值