深入Spring Boot :整合Redis详解

news/2024/5/5 4:59:31/文章来源:https://blog.csdn.net/AS011x/article/details/126619046

Spring Boot为Redis的Lettuce和Jedis客户端库提供了基本的自动配置,并且可以使用Spring Data Redis完成更多的操作。本篇将介绍如何整合Redis及使用Redis实现简单的查询缓存,主要包括以下7部分内容:

  1. 缓存

  2. Redis

  3. Lettuce

  4. Spring Data Redis

  5. Spring Cache

  6. 整合Redis

  7. 小结

缓存

个人理解的缓存是指用于存储频繁使用的数据的空间,关注点是存储数据的空间和使用频繁的数据。缓存技术,简单的说就是先从缓存中查询数据是否存在,存在则直接返回,不存在再执行相应的操作获取数据,并将获取的数据存储到缓存中,它是一种提升系统性能的重要方法。

Redis

Redis是一个开源的、内存存储key-value类型的数据结构服务器,可用作数据库、高速缓存和消息队列代理。它支持的数据类型有字符串、哈希表、列表、集合、有序集合等,同时通过Redis Sentinel提供高可用,通过Redis Cluster提供分区功能。

Lettuce

Lettuce是一种可伸缩、线程安全、完全非阻塞的Redis客户端,多个线程可以共享同一个RedisConnection。它利用Netty NIO框架来高效地管理多个连接,从而提供了异步和同步数据访问方式,用于构建非阻塞的反应性应用程序。 整合Redis,可以通过使用 spring-boot-starter-data-redis,这种方式下,Spring Boot默认使用的Redis客户端是Lettuce。

Spring Data Redis

Spring Data是Spring的一个主要项目,目的是为了简化构建基于Spring框架应用的数据访问,包括非关系数据库、Map-Reduce框架、云数据服务等,另外也包含对关系数据库的访问支持。Spring Data Redis是Spring Data项目中的一个主要模块,它提供了从Spring应用程序中轻松配置和访问Redis的功能、提供了与应用交互的低级和高级抽象,使开发者摆脱了对基础结构的关注,例如提供了RedisCacheManager。

Spring Cache

从Spring3.1开始,Spring框架提供了对Cache的支持,提供了一个对缓存使用的抽象,通过在既有代码中添加少量它定义的各种annotation,即能够达到缓存方法的返回对象的作用。提供的主要注解有@Cacheable、@CachePut、@CacheEvict和@Caching,具体见表1。

表1

@Cacheable的常用属性及说明如表2所示。

 

表2

SpEL表达式可以获取的值如表3所示。

表3

@CachePut的常用属性同@Cacheable。 @CacheEvict的常用属性见表4。

表4

当需要在类上或方法上同时使用多个注解时,可以使用@Caching,如@Caching(cacheable = @Cacheable("User"), evict = {@CacheEvict("Member"), @CacheEvict(value = "Customer", allEntries = true)})

整合Redis

在pom.xml或build.gradle中添加 spring-boot-starter-data-redis依赖即可,默认使用Lettuce客户端,依赖管理将会自动下载Lettuce对应的jar,例如在build.gradle文件中添加如下依赖:

compile group: 'org.springframework.boot', name: 'spring-boot-starter-data-redis', version: '2.0.0.RELEASE'

在application.properties或application.yml中添加Redis服务配置,例如在application.properties中添加如下基础配置:

#Redis服务器主机地址

spring.redis.host=127.0.0.1

#Redis服务连接密码

spring.redis.password=123456

#Redis对外服务端口

spring.redis.port=6379

更多Redis的高级配置(哨兵模式、主从)可以在spring-boot-autoconfigure包的 spring-configuration-metadata.json中查看。

spring-configuration-metadata.json

编写业务代码实现简单的查询缓存:

@Service

public class BankServiceImpl implements BankService {

@Autowired

private BankMapper bankMapper;

@Cacheable(value = "bank", key = "'BankId_' + #id", condition = "#id<=100")

@Override

public Bank findBy(Long id) {

return bankMapper.findById(id);

}

}

在application.properties或application.yml中配置一些缓存的配置,例如在application.properties添加如下配置:

#在写入Redis时是否要使用key前缀

spring.cache.redis.use-key-prefix=true

#key前缀

spring.cache.redis.key-prefix=banks_

#是否允许null值

spring.cache.redis.cache-null-values=false

#缓存有效时间,单位毫秒,默认长久有效

spring.cache.redis.time-to-live=5000

小结

当Redis可用并正确配置,应用启动时,Spring Boot会自动配置一个RedisCacheManager,这个CacheManager会在第一次写入时默认创建缓存。上面的查询缓存代码只是一个简单的Redis使用示例,当然你也可以在代码中自动注入RedisConnectionFactory、StringRedisTemplate或RedisTemplate实例,使用它们完成更多的扩展需求。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_3420.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

瑞吉外卖 —— 2、后台登录和登出

1、后台登录功能 1.1、接口分析 通过浏览器调试工具 F12 可以发现&#xff0c;在登录页面点击登录后&#xff0c;发送 POST 请求 http://localhost:8080/employee/login &#xff0c;并将输入的账号和密码信息以 JSON 格式发送给后台 前端校验代码如下&#xff1a; 1.1.2、登…

Hadoop源码解析之Mapper数量计算公式

前言 据说&#xff0c;自0.20.0版本开始&#xff0c;Hadoop同时提供了新旧两套MapReduce API&#xff0c;并在后续版本中也同时支持这两种API的使用。新版本MR API在旧的基础进行了扩展&#xff0c;也制定了新的split计算方式。新版本MR API在包org.apache.hadoop.mapreduce及…

Python基于Django的汽车销售网站

本汽车销售商城采用的数据库是Mysql&#xff0c;使用Django框架开发。在设计过程中&#xff0c;充分保证了系统代码的良好可读性、实用性、易扩展性、通用性、便于后期维护、操作方便以及页面简洁等特点。 汽车销售商城主要是为了提高工作人员的工作效率和更方便快捷的满足用户…

Win7下安装Docker(虚拟机win7)

在虚拟机VM里面安装一个win7用于安装Docker docker-toolbox-windows-docker-toolbox安装包下载_开源镜像站-阿里云 直接下载圈起来的这个就好了 直接拷贝到虚拟机系统win7里面安装&#xff0c;全部勾起来直接下一步安装即可 安装好后&#xff0c;会有三个图标 直接点击Dock…

自动化情侣微信早报信息定时推送

文章目录一、效果展示二、配置config.txt&#xff08;重点&#xff09;2.1 填写appID和appsecret2.1 创建测试模板填写template_id2.4 填写user2.5 填写weather_key2.6 填写剩下其他框选内容即可三、运行软件3.1 选择config.txt文件并设定时间3.2 运行软件3.3 效果展示一、效果…

12种解决CSS旧问题的新技巧

如果您一直在使用CSS&#xff0c;那么很可能会遇到一些布局或跨浏览器兼容性等问题。例如&#xff0c;CSS3的样式不太适用于IE的某些旧版本。而有时候&#xff0c;当我们准备使用某项功能时&#xff0c;却发现它无法广泛地得到各种浏览器的行为支持。因此&#xff0c;在从事Web…

第13章Linux实操篇-进程管理(重点)

第13章Linux实操篇-进程管理(重点) 文章目录第13章Linux实操篇-进程管理(重点)13.1基本介绍13.2显示系统执行的进程13.2.1基本介绍13.2.2ps详解13.2.3应用实例13.3终止进程kill和killall13.3.1介绍13.3.2基本语法13.3.3最佳实践13.4查看进程树pstree13.4.1基本语法13.4.2常用选…

Vue.js核心技术解析与uni-app跨平台实战开发学习笔记 第12章 Vue3.X新特性解析 12.1 Vue3.0 新特性

Vue.js核心技术解析与uni-app跨平台实战开发学习笔记 文章目录Vue.js核心技术解析与uni-app跨平台实战开发学习笔记第12章 Vue3.X新特性解析12.1 Vue3.0 新特性第12章 Vue3.X新特性解析 12.1 Vue3.0 新特性 Vue3.0 中需要重点关注的两个新特性&#xff1a; 双向数据绑定的原…

JVM资料阅读笔记总结-1

前言 最近读周志明的《深入理解Java虚拟机》以及半栈工程师的Java虚拟机文章&#xff0c;对JVM又重新复习了一遍&#xff0c;每次看后收获都不一样&#xff08;因为没有debug能力&#xff0c;还是很懵懂&#xff09;&#xff0c;担心会忘记将自己读后总结记录下来 总结内容 j…

期货开户止损是通向成功的保障

一、情绪波动止损法&#xff1a; 如果买入股票后&#xff0c;感觉不好&#xff0c;寝食难安&#xff0c;这说明自己认为买入理由不充分或信心不足&#xff0c;这将影响今后的正常操作&#xff0c;故应果断卖出离场。 二、空间位移止损法&#xff1a; 1、 初始止损法&#xf…

调用MapReuce对文件中各单词出现次数统计

调用MapReduce对文件中各单词出现次数统计 调用MapReuce对文件中各单词出现次数统计一、安装环境二、需求分析 1.创建hadoop账户2.设置Hadoop密码3.为Hadoop用户增加管理员权限4.更新apt5.安装vim6.安装SSH、配置SSH无密码登陆 三、安装java环境 1.安装JDK2.验证JDK安装情况3.…

SpringBoot 启用 GZIP 对响应进行压缩

SpringBoot Web 应用默认是不启用响应数据的压缩&#xff0c;对大的文本类型的响应数据进行压缩是十分必要的&#xff0c;如 JSON, XML 等应用数据&#xff0c;甚至是 JS, CSS 等。 早先的 Web 应用基本是要配置一个叫做 GzipFilter 之类的东西&#xff0c;然后判断请求的 Acc…

Windows与网络基础-1-2-虚拟机安装Windows10和window server2016

目录 一、虚拟机安装软件和ios镜像文件 二、新建虚拟机 2.1 文件—>新建虚拟机 2.2 选择典型安装 2.3 选择稍后安装 2.4 选择操作系统类型和版本 2.5 虚拟机名称和安装路径 2.6 指定磁盘大小 2.7 配置硬件信息 2.8 进入系统安装界面 2.9 选择系统版本 2.10 选择自…

LeetCode精选200道--二叉树篇(二)

二叉树篇&#xff08;二&#xff09;前言完全二叉树的节点个数普通二叉树逻辑递归完全二叉树逻辑平衡二叉树题外话递归二叉树的所有路径思路递归相同的树100. 相同的树另一棵树的子树左叶子之和思路找树左下角的值思路112. 路径总和思路106. 从中序与后序遍历序列构造二叉树根据…

FLASH:一种高效的Transformer设计

背景 近年来&#xff0c;Transformer凭借其优秀的设计&#xff0c;在文本、图像、语音等方向大杀四方。但是由于其attention的二次复杂度限制了其在长序列上的应用。本文提出了一种快(速度快)、省(省显存)的模型FLASH(Fast Linear Attention with a Single Head)&#xff0c;在…

SpringBoot 和 Vue前后端分离在线工具项目实战,源码+超详细讲解

一、前言 主要通过SpringBoot和Vue来实现一个前后端分离的在线工具平台&#xff0c;包含PDF转换、图片处理、文本处理、图表展示、二维码工具等功能。 为了更直观展示项目效果&#xff0c;也给大家提供了在线体验地址&#xff1a;http://49.234.28.149, 源码资源见文末。 通过…

org.apache.ibatis.binding.BindingException: Invalid bound statement (not found):

org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): 无效的绑定语句(未找到),就是写的sql 方法找不到sql。解决: 1 namespace 指向是否正确 路径与引用的方法的路径保持一致a.namespace 没有指向Dao b. id ,方法名没有对应上2 引用的方法…

记录Kettle连不上mysql8

如图所示&#xff0c;mysql升级到8了。 在很早之前&#xff0c;我一直用的是Mysql 5的驱动包去连接数据库&#xff0c;今天发现突然连接不上了&#xff0c;想了一下&#xff0c;应该是我以前升级mysql后的原因&#xff0c;换了mysql8的驱动后依旧没个卵用。 报错如下&#xff…

远程Debug远端服务器JVM配置

远程调试非本机的Java进程 远端Java进程启动的JVM参数 注意&#xff1a;以下配置尽量不要在线上生产环境开启&#xff0c;或者 JDK4: -Xdebug -Xrunjdwp:transportdt_socket,servery,suspendn,address{port} JDK5-JDK8: -agentlib:jdwptransportdt_socket,servery,suspen…

Python——LeetCode刷题——【383. 赎金信】

题目描述&#xff1a; 解题思路&#xff1a; 用字典记录字符串magazine中每个字符出现的次数。然后看看字典中magazine的各个字符的出现次数是否“够”字符串ransomNote中各个字符出现的次数。如果够&#xff0c;return True。如果存在有点字符不够&#xff0c;return False。…