码迷,mamicode.com
首页 > 其他好文 > 详细

redis 缓存雪崩问题的分析

时间:2019-04-13 10:52:58      阅读:150      评论:0      收藏:0      [点我收藏+]

标签:没有   获取   tco   else   超时   请求   redis   排队   filter   

缓存雪崩问题

缓存在同一时间内大量键过期(失效),接着来的一大波请求瞬间都落在了数据库中导致连接异常。

解决方案

1.加锁排队

2.建立备份缓存,缓存A和缓存B,A设置超时时间,B不设置超时时间,先从A读缓存,A没有读B,并且更新A缓存和B缓存;

3.设置缓存超时时间的时候加上一个随机的时间长度,比如这个缓存Key的超时间是固定的5分钟加上随机的2分钟,这样子可从一定程度上避免雪崩问题。

 

public String GetByKey(string key){

  //通过key获取value  

  String value=redisService.get(key);

  if(StringUtil.isEmpty(value)){

    if(bloomFilter.mightContain(key)){

      value =userService.getById(key);

      redisService.set(key,value);

      return value;

    }else{

      return null;

    }

  }

  return value;

}

redis 缓存雪崩问题的分析

标签:没有   获取   tco   else   超时   请求   redis   排队   filter   

原文地址:https://www.cnblogs.com/TwoTao/p/10699855.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!