学成在线之缓存
一:缓存
把白名单可以看到的信息和学生用户下的我的学习,我的选课等这些信息,存到缓存中,因为这些查询量比较大。
当查询时,先去检查缓存中是否有这个数据,如果有,就直接返回
如果没有,就去数据库中查询,再把数据添加到缓存中。
1:你是如何使用缓存的?
调用redisTemplate的get和set方法来获取值和将值存入缓存中
2:数据类型是怎么转换的?
在缓存中得到的json类型的,先转成json串,再转换为具体的对象类型
存入缓存时,将得到的对象,转换为json串
3:使用的是什么方法?
json的parseOBject和json的tojsonString
二:缓存穿透
当有大量线程查询一个根本不存在的课程的相关信息时,会直接在数据库中查,并且不会存入缓存,所以为了避免发生缓存穿透,所以我实现了布隆过滤器,提前将要存入redis的课程的id存入一个布隆过滤器当中,当要查询课程时,先在布隆过滤器中判断一下这个课程在不在,查不到会返回0,但是返回1时,代表可能存在。
三:缓存雪崩
我是对这一类查询课程的相关信息的key设置的过期时间不同,这样就不会有key在同时间过期,防止发生缓存雪崩
四:缓存击穿
为了防止热门课程的缓存过期,而导致大量请求到达数据库,就把某些热门课程的key设置为永不过期。,这样就不会发生缓存击穿。