视频地址: https://www.bilibili.com/video/BV1Ha411c7hB
代码地址: https://gitee.com/crazyliyang/video-teaching.git
1. 缓存穿透
缓存穿透,是指查询一个数据库一定不存在的数据。
正常的使用缓存流程大致是,数据查询先进行缓存查询,如果key不存在或者key已经过期,再对数据库进行查询,并把查询到的对象,放进缓存。如果数据库查询对象为空,则不放进缓存。
查询一个根部不存在的Key, 必然就会每次都去查询数据库,而每次查询都是空,每次又都不会进行缓存。假如有恶意攻击,就可以利用这个漏洞,对数据库造成压力,甚至压垮数据库.
代码流程如下:
/**
1.参数传入对象主键ID
2.根据redisKey从缓存中获取对象
3.如果缓存对象不为空,直接返回
4.如果缓存对象为空,进行数据库查询
5.如果从数据库查询出的对象不为空,则放入缓存
*/
public ProductEntity getById(Serializable id) {
String redisKey = buildKey(String.valueOf(id)); // 根据ID 构建rediskey
String redisVa