面试的时候,面试官问了我关于项目的Redis的一个缓存问题:
用Redis缓存登录验证码的时候,如果同时段大量验证码同时过期了,你会怎么处理这个问题
其实这是个缓存雪崩的问题,但我当时就懵了,还是面试面的少,技术也不行,赶紧来补了
什么是缓存
先讲一下什么是缓存,缓存的工作原理:先从缓存中获取数据,如果有数据则直接返回给用户,如果没有数据则从慢速设备上读取实际数据并且将数据放入缓存。
缓存雪崩
其实就是:缓存击穿强调单Key过期+高并发; 缓存雪崩强调多key过期+高并发。
(所以,缓存雪崩不是缓存崩了,是一大片大片的缓存数据都在同一时间都失效了)
为什么会瞬间有大量数据过期呢?
①大量数据同时放入缓存+过期时间设置的时间是一致的
②大量数据放入缓存的时间点不一样,但是过期时间是同一时间过期
缓存雪崩的解决思路
1、我们可以改变数据放入缓存的的时间,也可以选择修改数据的过期时间,让过期时间不一致,最终的目的是让数据分散在不同的时间点过期,从而减少数据库的高并发压力。很显然,修改数据的过期时间更简单一些,让缓存时间在一定的区域随机取值,很轻松就能解决了一个缓存雪崩的问题。
2、既然是因为并发访问导致,我们可以由高并发转换低并发,称之为互斥锁,或者分布式锁等,总之,加锁来保证高并发转换成低并发。