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数据一致性问题
- 先保证数据库的安全
- 后确定数据库数据的一致性
002 Redis使用及API的更多相关文章
- Redis C客户端API - God's blog - 博客频道 - CSDN.NET
Redis C客户端API - God's blog - 博客频道 - CSDN.NET Redis安装步骤: 1.redis server安装 wget http://redis.googlecod ...
- redis特性 存储 API 集群 等
公司组内技术分享,刚好最近工作用redis构建缓存,所以想同事们分享关于redis的一些知识, 这些知识不仅仅是包括一些API层,而是一些关于redis功能功能特性的 目前为什么使用redis构建缓存 ...
- jedis实现操纵redis的常用api及使用场景
简单记录一下,和描述一下常用的业务场景.好记性不如烂笔头. pom.xml <!--整合redis--> <dependency> <groupId>redis.c ...
- 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 创 ...
- Redis之hiredis API (String)
String // // Created by zhangrongxiang on 2018/3/7 13:48 // File string2 // #include <hiredis/hir ...
- redis - redis数据结构与API
通用命令 keys:遍历所有的key[keys一般不再生产环境使用],时间复杂度O(n) keys * keys he* keys he[h-l]* keys ph? dbsize:计算key的总数, ...
- redis: Jedis API(十四)
1.Key操作 package com.kuang; import redis.clients.jedis.Jedis; import java.util.Set; public class Test ...
- redis python操作api
redis单例数据库 #redis单例连接 ''' redis-server redis_diy.conf ''' import redis conn=redis.StrictRedis(host=' ...
- 在同一个方法里,有redis,数据库和api,如何保证方法的事务性或者最终一致性?
https://segmentfault.com/q/1010000017519179/a-1020000017547192
随机推荐
- 超耐心地毯式分析,来试试这道看似简单但暗藏玄机的Promise顺序执行题
壹 ❀ 引 就在昨天,与朋友聊到JS基础时,她突然想起之前在面试时,遇到了一道难以理解的Promise执行顺序题.由于我之前专门写过手写promise的文章,对于部分原理也还算了解,出于兴趣我便要了这 ...
- NFS学习笔记
一.NFS原理 ## 本次实验以CentOS7.7为例 [root@qll251 ~]# cat /etc/redhat-release CentOS Linux release 7.7.1908 ( ...
- 用js给闺女做了一个加减乘除的html
下班回家用二十分钟给闺女做了一个加减乘除的页面,顺便记录下代码,时间仓促,后期再来修改吧 目录结构 -yq --menu.html --yq.html --yq50.html --yq70.html ...
- MySQL 事务常见面试题总结 | JavaGuide 审核中
<Java 面试指北>来啦!这是一份教你如何更高效地准备面试的小册,涵盖常见八股文(系统设计.常见框架.分布式.高并发 ......).优质面经等内容. 本文原发于 MySQL知识点&am ...
- 【单片机】CH32V103串口IDLE空闲中断
CH32V103c8t6 在寻找解决接收完数据后,怎么即时判断数据已经完成了接收.发现串口有一个IDLE空闲中断.如下图描述: 意思是在串口接收完一帧数据 会产生一个中断,此时程序可判断为数据已接收完 ...
- C#与SQL Server连接时,如何编写连接字符串?
一.Windows身份验证时: String conStr = "Data Source=数据库服务器地址;Initial Catalog=数据库名称;Integrated Security ...
- Spring基础只是—AOP的概念介绍
Spring容器包含两个重要的特性:面向切面编程(AOP)和控制反转(IOC).面向切面编程是面向对象(OOP)的一种补充,在面向对象编程的过程中编程针对的目标是一个个对象,而面向切面编程中编程针对的 ...
- 开发工具-Typora编辑器下载地址
更新记录 2022年6月10日 完善标题. 比较好用的Markdown编辑器了,哈哈. https://typoraio.cn/
- MongoDB学习总览
第1部分: MongoDB入门(第1~6章) 该部分介绍MongoDB的基本概念及入门知识. 通过该部分的学习,读者可对MongoDB自身的技术全貌形成一定的认识. 第2部分: MongoDB微服务开 ...
- 六、LVM和从磁盘配额
一.LVM概述 Logical Volume Manager,逻辑卷管理 优点:能够保证在现有数据不变的情况下,动态调整磁盘容量,从而提高磁盘管理的灵活性 /boot分区用于存放引导文件,不能基于LV ...