缓存基础概念

1 缓存穿透

缓存穿透指的是用户不断对缓存和数据库中都没有的数据发起请求,例如id为负数或特别大的数,导致数据库压力过大。穿透可以想象成幽灵穿过墙壁一样,什么都没有碰到,就像数据库和缓存都没有命中。

一般情况下不会发生缓存穿透,较大可能是有人恶意攻击。

解决方案:

  1. 接口层添加参数校验,对于不合法参数直接拦截,例如id为负数的请求。
  2. 无法直接判断是否合法的话,如果数据库和缓存都没有命中,则把对应的id设置一个值保存到缓存中,这样下次请求同个id就直接返回我们设置的值。
  3. 缓存预热:将数据提前加入到缓存中,当数据发生变更的时候再更新到缓存中。

2 缓存击穿

缓存击穿指的是缓存中没有,但是数据库有的数据,如果并发用户特别多的话,一瞬间同时请求某条数据,缓存中没有读到,则同时请求数据库,导致数据库压力过大。

电商秒杀等场景容易发生缓存击穿。

解决方案:

  1. 设置热点数据永不过期。
  2. 缓存预热。

3 缓存雪崩

缓存雪崩指的是大批量缓存同时过期,同时请求数据库,导致数据库压力过大甚至宕机。缓存雪崩和缓存击穿的区别是,雪崩是同时并发查大量数据,击穿只是单条数据。

解决方案:

  1. 批量保存缓存数据的情况下,给过期时间加上一个随机数,防止同时大批量过期。
  2. 设置热点数据永不过期。
  3. 缓存预热。

你可能感兴趣的:(Java)