SpringBoot 整合Redis

在Spring Boot中,你可以使用以下注解来实现Redis的整合:

  1. @EnableCaching: 在启动类上添加该注解,开启Spring的缓存支持。

  2. @Cacheable: 标记方法的返回值可被缓存。当缓存中存在相同 key 的数据时,直接从缓存中获取数据,否则执行方法并将返回值存入缓存。

  3. @CachePut: 标记方法的返回值将会被更新到缓存中。即使缓存中已经存在相同 key 的数据,也会执行方法并将更新后的返回值存入缓存。

  4. @CacheEvict: 从缓存中移除指定 key 的数据。可以通过设置不同的属性来控制是在方法执行前移除还是在方法执行后移除。

  5. @Caching: 在方法级别上进行复杂的缓存操作,如组合多个缓存注解的行为。

  6. @CacheConfig: 配置全局的缓存配置,可以在类级别上设置缓存的一些公共配置,如缓存名称、缓存管理器等。

下面是一个简单的示例:

java 复制代码
import org.springframework.cache.annotation.Cacheable;
import org.springframework.stereotype.Service;

@Service
public class UserService {

    @Cacheable(value = "users", key = "#userId")
    public User getUserById(String userId) {
        // 从数据库或其他数据源中获取用户信息
        return userRepository.findById(userId);
    }
    
    // ...
}

上述示例中,@Cacheable 注解标记的方法 getUserById 可以被缓存,当传入相同的 userId 参数时,会直接从缓存中获取数据,而不会执行方法体内的代码。

需要注意的是,为了使用Redis作为缓存管理器,你需要在项目中引入相应的依赖,并在配置文件中配置Redis连接信息。例如,可以使用 spring-boot-starter-data-redis 依赖,并在 application.propertiesapplication.yml 中配置 Redis 相关属性。

相关推荐
云技纵横2 小时前
一个 @Async 让循环依赖暴雷:Spring 代理的暗坑
redis
未秃头的程序猿3 小时前
Java 26正式发布!这3个新特性,让代码量直接减半
java·后端·面试
用户298698530143 小时前
Word 文档文本查找与替换的 Java 实现方案
java·后端
阿哉4 小时前
Nacos 服务发现源码:藏在背后的两套事件机制,90%的人只讲了一半
java
咖啡八杯4 小时前
GoF设计模式——命令模式
java·设计模式·架构
AI人工智能_电脑小能手4 小时前
【大白话说Java面试题 第125题】【并发篇】第25题:说说 Java 线程的中断机制
java·后端·面试
Java内核笔记4 小时前
Spring Security 源码解析(六)无状态 JWT 实践:Session 共享与自定义过滤器
java·后端
荣码4 小时前
LangGraph多Agent协作:3个Agent干活比1个强,但我踩了4个坑
java·python
唐青枫6 小时前
Java 虚拟线程实战指南:从 Thread API 到 Spring Boot 高并发应用
java
白鲸开源1 天前
Apache SeaTunnel Zeta Engine 的 Basic Auth 是怎么工作的?
java·vue.js·github