Redis常见三大问题(缓存击穿,缓存穿透,缓存雪崩)
缓存穿透
简介
缓存击穿是指用户请求访问的数据不存在,导致请求穿过redis到达数据库层,如果有人恶意使用爬虫来不断攻击,会有大量的请求导致数据库宕机
为了防止这种情况,那么有以下两个办法
- 缓存空对象
- 布隆过滤器
缓存空对象
缓存空对象是最简单的方法,当请求第一次穿过redis,达到数据库的时候,若数据库中并没有相应的数据,那么可以返回一个空对象到redis中,设置一个较短的TTL过期时间,这样之后的请求中就可以读取的redis中含有空对象。
优点:
操作简单,实现方式容易,不会出现,代码维护简单
缺点:
- 容易造成短期的数据不一致,可能会对业务接口有影响
- 占用缓存空间多
代码实现
String get(String key