当前位置: 首页 > backend >正文

在Spring Boot中集成Redis进行缓存

在Spring Boot中集成Redis进行缓存,主要分为以下步骤:


1. 添加依赖

pom.xml中添加Redis和缓存相关的依赖:

<!-- Spring Boot Redis Starter -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId>
</dependency><!-- 可选:对象序列化支持(如Jackson) -->
<dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId>
</dependency>

2. 配置Redis连接

application.propertiesapplication.yml中配置Redis服务器信息:

# Redis基础配置
spring.redis.host=localhost
spring.redis.port=6379
spring.redis.password=  # 若无密码则留空
spring.redis.database=0# 连接池配置(可选)
spring.redis.lettuce.pool.max-active=8
spring.redis.lettuce.pool.max-idle=8
spring.redis.lettuce.pool.min-idle=0

3. 启用缓存功能

在启动类上添加@EnableCaching注解:

@SpringBootApplication
@EnableCaching // 启用缓存
public class Application {public static void main(String[] args) {SpringApplication.run(Application.class, args);}
}

4. 配置缓存管理器(可选但推荐)

自定义Redis缓存配置(如设置过期时间、序列化方式):

import org.springframework.cache.annotation.EnableCaching;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.cache.RedisCacheConfiguration;
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializationContext;@Configuration
@EnableCaching
public class RedisCacheConfig {@Beanpublic RedisCacheConfiguration cacheConfiguration() {return RedisCacheConfiguration.defaultCacheConfig().entryTtl(Duration.ofMinutes(10)) // 默认缓存过期时间:10分钟.disableCachingNullValues() // 不缓存null值.serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new GenericJackson2JsonRedisSerializer() // 使用JSON序列化));}
}

5. 在Service层使用缓存注解

在需要缓存的方法上添加Spring Cache注解:

注解作用
@Cacheable查询时优先读缓存,无缓存则执行方法并保存结果
@CachePut每次执行方法并更新缓存(常用于更新操作)
@CacheEvict删除缓存(常用于删除或更新操作)

示例代码:

@Service
public class UserService {// 根据ID查询用户(结果缓存到"users"区域,key为#id)@Cacheable(value = "users", key = "#id")public User getUserById(Long id) {// 模拟数据库查询return userRepository.findById(id).orElse(null);}// 更新用户信息(同时更新缓存)@CachePut(value = "users", key = "#user.id")public User updateUser(User user) {return userRepository.save(user);}// 删除用户(同时移除缓存)@CacheEvict(value = "users", key = "#id")public void deleteUser(Long id) {userRepository.deleteById(id);}// 清除"users"区域所有缓存(如批量更新后)@CacheEvict(value = "users", allEntries = true)public void clearAllUserCache() {}
}

6. 验证缓存效果

  • 观察日志:首次查询会访问数据库,后续相同请求不会打印SQL。
  • Redis命令行检查
    redis-cli
    > KEYS *      # 查看所有缓存键
    > GET "users::1"  # 查看key为1的用户缓存
    
  • 强制刷新缓存:更新数据后,检查缓存是否被清除/更新。

常见问题解决

  1. 序列化异常

    • 确保实体类实现java.io.Serializable接口。
    • 使用JSON序列化(如GenericJackson2JsonRedisSerializer)。
  2. 缓存穿透

    • 对空结果也进行短时间缓存(需自定义配置)。
    • 使用@Cacheableunless参数:
      @Cacheable(value="users", unless="#result == null")
      
  3. 缓存一致性

    • 更新数据库后立即清除或更新缓存(通过@CachePut/@CacheEvict)。

通过以上步骤,即可在Spring Boot中高效集成Redis实现缓存功能,显著提升应用性能。

http://www.xdnf.cn/news/10280.html

相关文章:

  • 赛博算命之“帝王之术”——奇门遁甲的JAVA实现
  • Dest建筑能耗模拟仿真功能简介
  • 业界宽松内存模型的不统一而导致的软件问题, gcc, linux kernel, JVM
  • 流媒体基础解析:视频清晰度的关键因素
  • 深度学习|pytorch基本运算-广播失效
  • 方案精读:42页华为企业组织活力设计方案【附全文阅读】
  • 什么是trace,分布式链路追踪(Distributed Tracing)
  • C++ 建造者模式:简单易懂的设计模式解析
  • 保持本地 Git 项目副本与远程仓库完全同步
  • LeetCode 每日一题 2025/5/26-2025/6/1
  • DO指数GPU版本
  • Redis最佳实践——安全与稳定性保障之高可用架构详解
  • 双目相机深度的误差分析(基线长度和相机焦距的选择)
  • python中将一个列表样式的字符串转换成真正列表的办法以及json.dumps()和 json.loads()
  • 谷歌工作自动化——仙盟大衍灵机——仙盟创梦IDE
  • Cypress + React + TypeScript
  • Mybatis:灵活掌控SQL艺术
  • 分享两款使用免费软件,dll修复工具及DirectX修复工具
  • 西瓜书第五章——感知机
  • Qt程序添加调试输出窗口:CONFIG += console
  • Oracle中EXISTS NOT EXISTS的使用
  • 关于用Cloudflare的Zero Trust实现绕过备案访问国内站点说明
  • SEO长尾关键词优化进阶指南
  • springboot集成websocket给前端推送消息
  • Visual Studio笔记:MSVC工具集、MSBuild
  • 【HW系列】—日志介绍
  • Excel快捷键
  • ESP8266常用指令
  • LeetCode Hot100刷题——划分字母区间
  • 第十四篇:MySQL 运维中的故障场景还原与排查实战技巧