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缓存!穿透

  1. 实现Redis缓存的配置,接口,实现类
  2. 业务层中调用Redis

6.缓存预热

核心价值: 就是为了提高查询效率

  1. 影响运行效率
  2. 删除旧数据
  3. 加载新数据
    1. 总表一份
    2. 各独立列表各一份
  4. 封装redisTemplate--高内聚,低耦合
1.创建组件类CachePreLoad(创建缓存预热),并实现 ApplicationRunner接口
2.查询:获取category的所有信息,Mapper/xml/test
3.查询到的数据写入Redis: 

   - Redis接口中写抽象方法,并实现;
   
  - 常量: KEY:category:list;
4.list集合是追加的,所以每一次
  - 预热前,需要执行删除操作deleteList()

** 从设计的角度来讲,Mapper和其他Repository组件,只能够被Service调用;**


晚课:



注意事项:

  • Redis数据安全
    • 高穿透: 高频率透过Redis访问数据库
  • Redis数据一致性问题
    • 先保证数据库的安全
    • 后确定数据库数据的一致性
posted @ 2022-07-16 12:11  Y_Zoran  阅读(80)  评论(0)    收藏  举报
-->