Redis是开发过程中经常使用到的工具,这里简单说一下如何解决穿透,雪崩的问题。
穿透:
1、利用互斥锁。缓存失效的时候,得到了锁,再请求数据库。没得到锁,休眠一段时间重试。
2、采用异步更新策略。无论key是否取到值,都直接返回。value值中维护一个缓存失效时间,缓存如果过期,异步一个线程去读数据库,跟新缓存。需要缓存预热(项目启动前,先加载缓存)。
3、提供一个能迅速判断请求是否有效拦截机制。如布隆过滤器,内部维护一系列合法有效的key,迅速判断出请求的key合不合法。
雪崩:
1、给缓存的失效时间加上随机值,避免集体失效。
2、利用互斥锁。但会导致吞吐量下降。
3、使用双缓存。一个设失效时间(A),一个不失效(B),做缓存预热。从A读数据库,有则直接返回;无就从B读,且异步启动一个更新线程,同时更新A,B。