本地缓存防止缓存击穿_防止缓存爆炸的快速提示

本地缓存防止缓存击穿

在很多情况下,您都可以从应用程序中的常用对象缓存中受益,特别是在面向Web和微服务的环境中。 您可以在Java中执行的最简单的缓存类型可能是引入一个私有HashMap,在计算对象之前先查询该哈希表,以确保您不会重复执行此操作。

这是一个例子:

public class PrimeService {

    private Map<Long, BigInteger> cache = new HashMap<>();
    
    public BigInteger getPrime(long minimum) {
        return cache.computeIfAbsent(minimum, 
            m -> BigInteger.valueOf(m).nextProbablePrime()
        );
    }
    
}

这是解决该问题的快速方法,但遗憾的是效率不高。 在几个月后人们将各种各样的疯狂数字输入到服务中之后,我们将拥有一个非常大的HashMap,这可能会导致我们的内存不足。

这是解决这个问题的快速技巧。 除了使用HashMap,还可以使用LinkedHashMap并简单地覆盖方法removeEldestEntry。 这样,您就可以配置自己的限制功能以防止地图爆炸。

public class PrimeService {

    public final static int CACHE_MAX_SIZE = 1_000;

    private Map<Long, BigInteger> cache = new LinkedHashMap<>() {
        @Override
        protected boolean removeEldestEntry(Map.Entry<ID, Boolean> eldest) {
            return size() > PrimeService.CACHE_MAX_SIZE;
        }
    };
    
    public BigInteger getPrime(long minimum) {
        return cache.computeIfAbsent(minimum, 
            m -> BigInteger.valueOf(m).nextProbablePrime()
        );
    }
    
}

现在,我们已经成功限制了缓存,防止了缓存爆炸。 随着新条目的添加,旧条目将被删除。 应该注意的是,这种解决方案在小型应用程序中效果很好,但是对于更高级的方案,您可能想使用外部缓存解决方案。 如果您有兴趣在不编写大量SQL代码的情况下在SQL数据库中缓存条目,我建议您使用Speedment,因为它是轻量级的并且具有非常流畅的API。

直到下一次!

翻译自: https://www.javacodegeeks.com/2016/12/quick-tip-prevent-caches-exploding.html

本地缓存防止缓存击穿

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值