redis 缓存雪崩问题的分析
Posted twotao
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了redis 缓存雪崩问题的分析相关的知识,希望对你有一定的参考价值。
缓存雪崩问题
缓存在同一时间内大量键过期(失效),接着来的一大波请求瞬间都落在了数据库中导致连接异常。
解决方案
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 缓存雪崩问题的分析的主要内容,如果未能解决你的问题,请参考以下文章