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数据一致性问题
    • 先保证数据库的安全
    • 后确定数据库数据的一致性

002 Redis使用及API的更多相关文章

  1. Redis C客户端API - God's blog - 博客频道 - CSDN.NET

    Redis C客户端API - God's blog - 博客频道 - CSDN.NET Redis安装步骤: 1.redis server安装 wget http://redis.googlecod ...

  2. redis特性 存储 API 集群 等

    公司组内技术分享,刚好最近工作用redis构建缓存,所以想同事们分享关于redis的一些知识, 这些知识不仅仅是包括一些API层,而是一些关于redis功能功能特性的 目前为什么使用redis构建缓存 ...

  3. jedis实现操纵redis的常用api及使用场景

    简单记录一下,和描述一下常用的业务场景.好记性不如烂笔头. pom.xml <!--整合redis--> <dependency> <groupId>redis.c ...

  4. 002.Create a web API with ASP.NET Core MVC and Visual Studio for Windows -- 【在windows上用vs与asp.net core mvc 创建一个 web api 程序】

    Create a web API with ASP.NET Core MVC and Visual Studio for Windows 在windows上用vs与asp.net core mvc 创 ...

  5. Redis之hiredis API (String)

    String // // Created by zhangrongxiang on 2018/3/7 13:48 // File string2 // #include <hiredis/hir ...

  6. redis - redis数据结构与API

    通用命令 keys:遍历所有的key[keys一般不再生产环境使用],时间复杂度O(n) keys * keys he* keys he[h-l]* keys ph? dbsize:计算key的总数, ...

  7. redis: Jedis API(十四)

    1.Key操作 package com.kuang; import redis.clients.jedis.Jedis; import java.util.Set; public class Test ...

  8. redis python操作api

    redis单例数据库 #redis单例连接 ''' redis-server redis_diy.conf ''' import redis conn=redis.StrictRedis(host=' ...

  9. 在同一个方法里,有redis,数据库和api,如何保证方法的事务性或者最终一致性?

    https://segmentfault.com/q/1010000017519179/a-1020000017547192

随机推荐

  1. 小干货:Linux 系统的备份恢复

    点击上方"开源Linux",选择"设为星标" 回复"学习"获取独家整理的学习资料! tar 命令 副本(本机备份整个系统,以后还原还是还原到 ...

  2. Shell脚本实战:日志关键字监控+自动告警

    一个执着于技术的公众号 该程序使用场景说明:主要用于Linux服务器监控程序日志,如出现关键字异常则触发相应的动作或告警操作,通知到邮件联系人. 一.安装邮件服务 1.解压 tar -jxf mail ...

  3. CPU缓存L1/L2/L3工作原理

    点击上方"开源Linux",选择"设为星标" 回复"学习"获取独家整理的学习资料! 一.前言 在过去的几年中,计算机处理器取得了相当大的进步 ...

  4. 不懂 Zookeeper?来看看这篇文章

    开源Linux 长按二维码加关注~ 高并发分布式开发技术体系已然非常的庞大,从国内互联网企业使用情况,可发现RPC.Dubbo.ZK是最基础的技能要求.关于Zookeeper你是不是还停留在Dubbo ...

  5. 【总结】2022GDOI普及组试题与题解(缺两天的T4)

    标签 2022 广东省选普及组 GDOI 试题 前往Luogu下载 Luogu下载:This Day1题解 T1 邹忌讽齐王纳谏 打卡题,建议模拟 建议使用map,时间复杂度为\(O(nlogn)\) ...

  6. 2021 CSP-J复赛 我的备战与游记

    目录 备战 2021.10.18 2021.10.19 2021.10.20 2021.10.21 2021.10.22 比赛当日 早上 线下见面 正文 比赛后 赛后总结与讲解 简单总结 Candy ...

  7. python数据类型、用户交互和运算符

    基本数据类型 1.字典dict(dictionary) 能够准确的记录储存的信息 """ 大括号里面 放多个元素 之间用逗号隔开 元素为K:V键表示储存 K相对于V一般表 ...

  8. Linux磁盘和文件系统知识总结

    硬盘操作 为什么要给硬盘分区? 如果你需要在一块硬盘上用到多个文件系统,那么你就需要对硬盘进行分区,以便用不同的分区支持不同的文件系统.(但一个硬盘只能有一个分区表!)反过来说,如果你整块硬盘都用同样 ...

  9. WSL2-CentOS7固定IP

    WSL2-CentOS7固定IP WSL2 采用 Hyper-V 的 Internal Virtual Switch,这个虚拟交换机本身是可以设置静态 IP 地址的,但是 WSL2 却自作聪明,在每次 ...

  10. 一起看 I/O | Flutter 休闲游戏工具包发布

    作者 / Zoey Fan, Product Manager for Flutter, Google 对于大多数开发者来说,Flutter 是一个应用框架.但利用 Flutter 提供的硬件加速图形支 ...