002 Redis使用及API
Redis的使用及相关API
1.作用:
- 提高查询效率
- 一定程度上可以减轻数据库服务器的冲击压力,从而保护了数据库
//1.是否包含key redisTemplate.hasKey(key) //2.Value对象的保存及获取 redisTemplate.opsForValue().set(key, null, 30, TimeUnit.SECONDS); redisTemplate.opsForValue().get(key); //3.根据key获取List对象 for (CategoryDetailsVO category : categories) { redisTemplate.opsForList().rightPush(KEY_CATEGORY_LIST, category); } //4.根据key删除对象 Set<String> keys = redisTemplate.keys(KEY_CATEGORY_ITEM_PREFIX + "*"); redisTemplate.delete(keys);
2.应用场景
- 高频查询:例如:热搜列表、秒杀
- 改变频率低(数据查询度不是那么高)的数据,例如:商品类别
- 反之,则不能使用Redis
3.前提:
- 开发新的组件,实现对Redis中的数据访问----非必须但推荐(利于维护)
- 在Service中调用新的组件,在Service中决定何时访问MySQL,何时访问Redis
4.流程实例
1.明确问题:
1. 哪些数据功能改为从Redis中获取数据
2. Redis中的数据从哪里来
2.暂定目标
1.根据类别的id查询类别详情,改从Redis中获取数据;
2. 优先从Redis中获取数据,Redis中没有,则从MySQL中获取,且获取到的
数据存取到Redis中,所以经过首次查询,Redis中将存在数据,后续每一次
都可以直接从Redis中拿到必要的数据.
5.实现Redis缓存!穿透
- 实现Redis缓存的配置,接口,实现类
- 业务层中调用Redis
6.缓存预热
核心价值: 就是为了提高查询效率
- 影响运行效率
- 删除旧数据
- 加载新数据
- 总表一份
- 各独立列表各一份
- 封装redisTemplate--高内聚,低耦合
1.创建组件类CachePreLoad(创建缓存预热),并实现 ApplicationRunner接口
2.查询:获取category的所有信息,Mapper/xml/test
3.查询到的数据写入Redis:
- Redis接口中写抽象方法,并实现;
- 常量: KEY:category:list;
4.list集合是追加的,所以每一次
- 预热前,需要执行删除操作deleteList()
** 从设计的角度来讲,Mapper和其他Repository组件,只能够被Service调用;**
晚课:
注意事项:
- Redis数据安全
- 高穿透: 高频率透过Redis访问数据库
- Redis数据一致性问题
- 先保证数据库的安全
- 后确定数据库数据的一致性