Spring Boot3 整合 Redis 实现数据缓存操作全解析
mhr18 2025-03-20 16:35 18 浏览 0 评论
嘿,各位开发小伙伴们!在咱们日常开发中,数据读取速度可是个关键问题。你是不是也经常遇到项目中数据查询耗时较长,影响系统整体性能的情况呢?其实啊,很大一部分原因是没有合理利用数据缓存。今天,咱们就来深入探讨一下如何通过 Spring Boot3 与 Redis 的整合,实现高效的数据缓存操作,大幅提升项目性能。
背景介绍
Spring Boot 已经成为 Java 开发中最受欢迎的框架之一,到了 Spring Boot3 版本,更是带来了许多新特性和优化。它简化了 Spring 应用的搭建和开发过程,让开发者能更专注于业务逻辑的实现。而 Redis,作为一款高性能的键值对存储数据库,在缓存领域应用极为广泛。它支持多种数据结构,读写速度极快,并且具备高可用性和分布式特性。将 Spring Boot3 与 Redis 整合,能充分发挥两者的优势,为项目提供强大的数据缓存支持。
在实际开发场景中,比如电商平台的商品详情页,商品信息可能不会频繁变动,但每次用户访问都需要从数据库查询,这就造成了不必要的资源浪费。如果使用缓存,将商品信息缓存起来,下次用户访问时直接从缓存读取,就能极大提高响应速度,提升用户体验。
整合前的准备工作
项目搭建
首先,创建一个 Spring Boot3 项目。可以通过 Spring Initializr(https://start.spring.io/)来快速生成项目骨架。在配置项目时,选择添加 Spring Web Starter 和 Spring Data Redis Starter 依赖。这两个依赖分别用于支持 Web 开发和与 Redis 交互。
Redis 安装与配置
如果你是在本地开发测试,可以通过多种方式安装 Redis。比如在 Linux 系统下,可以使用包管理器安装,如在 Ubuntu 系统中,执行命令sudo apt - get install redis - server。安装完成后,需要配置 Redis。Redis 的配置文件通常位于/etc/redis/redis.conf,在这里可以设置 Redis 的绑定地址、端口、密码等信息。例如,将绑定地址改为0.0.0.0,以便可以从外部访问(注意在生产环境中要谨慎设置),设置密码为yourpassword。修改完成后,重启 Redis 服务使配置生效。
具体整合步骤
引入依赖
在项目的pom.xml文件中,确保已经引入了以下依赖:
org.springframework.boot
spring-boot-starter-web
org.springframework.boot
spring-boot-starter-data-redis
配置 Redis 连接信息
在 Spring Boot 的配置文件application.properties或application.yml中添加 Redis 连接信息。以application.yml为例:
spring:
redis:
host: 127.0.0.1
port: 6379
password: yourpassword
创建 Redis 配置类
创建一个配置类,用于配置 RedisTemplate 和相关的序列化方式。代码如下:
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;
@Configuration
public class RedisConfig {
@Bean
public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory) {
RedisTemplate template = new RedisTemplate<>();
template.setConnectionFactory(redisConnectionFactory);
template.setKeySerializer(new StringRedisSerializer());
template.setValueSerializer(new GenericJackson2JsonRedisSerializer());
template.setHashKeySerializer(new StringRedisSerializer());
template.setHashValueSerializer(new GenericJackson2JsonRedisSerializer());
return template;
}
}
这里使用了StringRedisSerializer来序列化键,
GenericJackson2JsonRedisSerializer来序列化值,这样可以方便地存储和读取各种对象。
使用缓存注解
Spring Boot 提供了方便的缓存注解,如@Cacheable、@CacheEvict、@CachePut等。
@Cacheable 注解:用于标记方法,当方法被调用时,如果缓存中存在对应的数据,则直接从缓存中返回,不再执行方法体。例如:
import org.springframework.cache.annotation.Cacheable;
import org.springframework.stereotype.Service;
@Service
public class ProductService {
@Cacheable(value = "products", key = "#productId")
public Product getProductById(String productId) {
// 这里模拟从数据库查询商品信息
return getProductFromDatabase(productId);
}
private Product getProductFromDatabase(String productId) {
// 实际从数据库查询逻辑
return new Product(productId, "Sample Product", 100.0);
}
}
在上述代码中,@Cacheable注解的value属性指定了缓存的名称为products,key属性指定了缓存的键为productId。当调用getProductById方法时,如果products缓存中存在键为productId的值,则直接返回,否则执行getProductFromDatabase方法查询数据库,并将结果存入缓存。
@CacheEvict 注解:用于清除缓存。比如当商品信息更新后,需要清除对应的缓存数据,代码如下:
import org.springframework.cache.annotation.CacheEvict;
import org.springframework.stereotype.Service;
@Service
public class ProductService {
@CacheEvict(value = "products", key = "#productId")
public void updateProduct(Product product) {
// 这里模拟更新商品信息到数据库
updateProductInDatabase(product);
}
private void updateProductInDatabase(Product product) {
// 实际更新数据库逻辑
}
}
@CachePut 注解:用于更新缓存。与@Cacheable不同,@CachePut会先执行方法体,然后将方法返回值存入缓存。例如:
import org.springframework.cache.annotation.CachePut;
import org.springframework.stereotype.Service;
@Service
public class ProductService {
@CachePut(value = "products", key = "#product.productId")
public Product saveProduct(Product product) {
// 这里模拟保存商品信息到数据库
return saveProductToDatabase(product);
}
private Product saveProductToDatabase(Product product) {
// 实际保存数据库逻辑
return product;
}
}
创建缓存工具类
除了使用注解,还可以创建一个缓存工具类,更加灵活地操作缓存。例如
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component;
import java.util.concurrent.TimeUnit;
@Component
public class RedisCacheUtil {
@Autowired
private RedisTemplate redisTemplate;
public void set(String key, Object value) {
redisTemplate.opsForValue().set(key, value);
}
public void set(String key, Object value, long timeout, TimeUnit timeUnit) {
redisTemplate.opsForValue().set(key, value, timeout, timeUnit);
}
public Object get(String key) {
return redisTemplate.opsForValue().get(key);
}
public void delete(String key) {
redisTemplate.delete(key);
}
}
通过这个工具类,可以方便地进行缓存的设置、获取和删除操作,并且可以设置缓存的过期时间。
总结
通过以上步骤,我们详细介绍了 Spring Boot3 与 Redis 的整合过程,以及在实际应用中的一些优化和高级应用。合理使用数据缓存,不仅能提升项目的性能,还能提高用户体验。各位开发小伙伴们,赶紧在自己的项目中尝试使用 Spring Boot3 整合 Redis 实现数据缓存吧!在实践过程中,如果遇到任何问题,欢迎在评论区留言交流。让我们一起通过技术优化,打造更高效、更强大的应用程序。
相关推荐
- B站收藏视频失效?mybili 收藏夹备份神器完整部署指南
-
本内容来源于@什么值得买APP,观点仅代表作者本人|作者:羊刀仙很多B站用户都有过类似经历:自己精心收藏的视频突然“消失”,点开一看不是“已被删除”,就是“因UP主设置不可见”。而B站并不会主动通知...
- 中间件推荐初始化配置
-
Redis推荐初始化配置bind0.0.0.0protected-modeyesport6379tcp-backlog511timeout300tcp-keepalive300...
- Redis中缓存穿透问题与解决方法
-
缓存穿透问题概述在Redis作为缓存使用时,缓存穿透是常见问题。正常查询流程是先从Redis缓存获取数据,若有则直接使用;若没有则去数据库查询,查到后存入缓存。但当请求的数据在缓存和数据库中都...
- 后端开发必看!Redis 哨兵机制如何保障系统高可用?
-
你是否曾在项目中遇到过Redis主服务器突然宕机,导致整个业务系统出现数据读取异常、响应延迟甚至服务中断的情况?面对这样的突发状况,作为互联网大厂的后端开发人员,如何快速恢复服务、保障系统的高可用...
- Redis合集-大Key处理建议
-
以下是Redis大Key问题的全流程解决方案,涵盖检测、处理、优化及预防策略,结合代码示例和最佳实践:一、大Key的定义与风险1.大Key判定标准数据类型大Key阈值风险场景S...
- 深入解析跳跃表:Redis里的"老六"数据结构,专治各种不服
-
大家好,我是你们的码农段子手,今天要给大家讲一个Redis世界里最会"跳科目三"的数据结构——跳跃表(SkipList)。这货表面上是个青铜,实际上是个王者,连红黑树见了都要喊声大哥。...
- Redis 中 AOF 持久化技术原理全解析,看完你就懂了!
-
你在使用Redis的过程中,有没有担心过数据丢失的问题?尤其是在服务器突然宕机、意外断电等情况发生时,那些还没来得及持久化的数据,是不是让你夜不能寐?别担心,Redis的AOF持久化技术就是...
- Redis合集-必备的几款运维工具
-
Redis在应用Redis时,经常会面临的运维工作,包括Redis的运行状态监控,数据迁移,主从集群、切片集群的部署和运维。接下来,从这三个方面,介绍一些工具。先来学习下监控Redis实时...
- 别再纠结线程池大小 + 线程数量了,没有固定公式的!
-
我们在百度上能很轻易地搜索到以下线程池设置大小的理论:在一台服务器上我们按照以下设置CPU密集型的程序-核心数+1I/O密集型的程序-核心数*2你不会真的按照这个理论来设置线程池的...
- 网络编程—IO多路复用详解
-
假如你想了解IO多路复用,那本文或许可以帮助你本文的最大目的就是想要把select、epoll在执行过程中干了什么叙述出来,所以具体的代码不会涉及,毕竟不同语言的接口有所区别。基础知识IO多路复用涉及...
- 5分钟学会C/C++多线程编程进程和线程
-
前言对线程有基本的理解简单的C++面向过程编程能力创造单个简单的线程。创造单个带参数的线程。如何等待线程结束。创造多个线程,并使用互斥量来防止资源抢占。会使用之后,直接跳到“汇总”,复制模板来用就行...
- 尽情阅读,技术进阶,详解mmap的原理
-
1.一句话概括mmapmmap的作用,在应用这一层,是让你把文件的某一段,当作内存一样来访问。将文件映射到物理内存,将进程虚拟空间映射到那块内存。这样,进程不仅能像访问内存一样读写文件,多个进程...
- C++11多线程知识点总结
-
一、多线程的基本概念1、进程与线程的区别和联系进程:进程是一个动态的过程,是一个活动的实体。简单来说,一个应用程序的运行就可以被看做是一个进程;线程:是运行中的实际的任务执行者。可以说,进程中包含了多...
- 微服务高可用的2个关键技巧,你一定用得上
-
概述上一篇文章讲了一个朋友公司使用SpringCloud架构遇到问题的一个真实案例,虽然不是什么大的技术问题,但如果对一些东西理解的不深刻,还真会犯一些错误。这篇文章我们来聊聊在微服务架构中,到底如...
- Java线程间如何共享与传递数据
-
1、背景在日常SpringBoot应用或者Java应用开发中,使用多线程编程有很多好处,比如可以同时处理多个任务,提高程序的并发性;可以充分利用计算机的多核处理器,使得程序能够更好地利用计算机的资源,...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle位图索引 (63)
- oracle批量插入数据 (62)
- oracle事务隔离级别 (53)
- oracle 空为0 (50)
- oracle主从同步 (55)
- oracle 乐观锁 (51)
- redis 命令 (78)
- php redis (88)
- redis 存储 (66)
- redis 锁 (69)
- 启动 redis (66)
- redis 时间 (56)
- redis 删除 (67)
- redis内存 (57)
- redis并发 (52)
- redis 主从 (69)
- redis 订阅 (51)
- redis 登录 (54)
- redis 面试 (58)
- 阿里 redis (59)
- redis 搭建 (53)
- redis的缓存 (55)
- lua redis (58)
- redis 连接池 (61)
- redis 限流 (51)