一、什么是缓存?作用?代价?
缓存:数据交换的缓冲区,存储数据的临时地方,一般读写性能比较高。
作用:降低后端负载;提升读写效率,提高响应速度。
缺点:数据一致性成本变高;代码维护成本变高;运营维护成本变高。
二、商户缓存实现流程
通俗来说就是:从数据库获取数据之前查询缓存;从数据库获取数据之后写入缓存。
三、给店铺类型查询页面添加缓存
这是虎哥在视频中留下的小作业。我在这里使用list类型来实现。
Controller:
@GetMapping("list")
public Result queryTypeList() {
/*List<ShopType> typeList = typeService
.query().orderByAsc("sort").list();*/
return typeService.queryTypeList();
}
实现类中:
@Override
public Result queryTypeList() {
//1.查询redis缓存
String key = RedisConstants.CACHE_SHOP_TYPE_KEY;
List<String> shopTypeList = stringRedisTemplate.opsForList().range(key, 0, -1);//获取所有值
//2.有缓存,直接返回
if (shopTypeList != null && shopTypeList.size() > 0) {
List<ShopType> shopTypes = new ArrayList<>();
shopTypeList.forEach(shopType -> {
ShopType shopType1 = JSONUtil.toBean(shopType, ShopType.class);
shopTypes.add(shopType1);
});
return Result.ok(shopTypes);
}
//3.无缓存,查询数据库
List<ShopType> shopTypes = query().list();
//4.无数据,返回错误
if (shopTypes == null){
return Result.fail("店铺类型查询失败");
}
//5.有数据,写入redis,返回
shopTypes.forEach(shopType -> {
stringRedisTemplate.opsForList().rightPush(key, JSONUtil.toJsonStr(shopType));
});
//6.返回
return Result.ok(shopTypes);
}
四、缓存更新策略(重点)
缓存更新:为了保证一致性,你就要对缓存进行更新,确保缓存数据和数据库数据一致
(1)缓存更新策略
(2)主动更新策略的三种方式。CacheAside综合来说比较好。
(3)主动更新的方案选好了,那么问题又来了,我们是更新缓存还是删除缓存呢?是先操作数据库还是先操作缓存呢?如何保证数据库和缓存操作的原子性呢?
(4)最佳实践
五、缓存穿透(重点)
商户缓存防止缓存穿透实现流程
六、缓存雪崩(重点)
七、缓存击穿(重点)
缓存击穿也叫热点key问题,就是热点key突然失效,导致大量访问该数据的请求打到数据库上,给数据库造成巨大的压力。
解决方案:
以上图片均来自虎哥发的资料。