redis雪崩

每个key(即数据)如果设置了失效时间的话,如果大量key同时过期的时候,或者说因为某种原因redis中的数据突然大批量丢失,这些key又大量地去请求这些key时,因为redis里面没有这些数据,就会大量的请求就会大量涌向数据库,就会导致数据库处理不过来,导致“雪崩”。

解决办法:

1、设置均匀的过期时间,避免某段时间出现大批量数据失效

2、在缓存失效后,通过加锁或者队列来控制读数据库写缓存的线程数量。比如对某个key只允许一个线程查询数据和写缓存,其他线程等待。

3、做二级缓存,一级缓存未查询到数据,则从二级缓存查询



原文地址:https://www.cnblogs.com/flzs/p/12205392.html