Springboot中的缓存使用

springboot 默认存储位置

默认缓存

复制代码
 JVM 堆内存, 默认缓存大小 16M,但旨在单个应用实例内有效,且缓存的数据量不会太大。

redis

复制代码
 缓存存储位置为 Redis, 分布式共享,多个应用实例可以共享缓存。

默认缓存使用步骤

1. 添加pom依赖

java 复制代码
  <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-cache</artifactId>
  </dependency>

2.在主应用类或配置类上添加 @EnableCaching 注解

java 复制代码
	@SpringBootApplication
	@EnableCaching
	public class SpringBootApiApplication {
	
	    public static void main(String[] args) {
	        SpringApplication.run(SpringBootApiApplication.class, args);
	
	    }
	
	}

3.业务方法增加缓存注解 @Cacheable(value = "users", key = "#name"),即开启缓存服务。

java 复制代码
  	@RequestMapping(value = "/users")
	@Cacheable(value = "User", key = "#name")
	public List<User> getUsers(String  name) {
	
	    //创建用户集合
	    List<User> users = new ArrayList<>();
	
	    // 添加空值检查避免 NullPointerException
	    if (name != null && !name.isEmpty()) {
	        // 使用stream流过滤
	        users = users.stream()
	                .filter(user -> user.getName() != null && user.getName().contains(name))
	                .toList();
	    }
	
	    return users;
	 }

 PS: @Cacheable: 表示该方法的结果可以被缓存 value = "users": 指定缓存名称 key = "#name": 使用方法参数 name 作为缓存的键

4.修改删除业务方法需要清楚缓存使用注解 @CacheEvict(value = "users", key = "#name")

5.配置redis缓存

复制代码
 * 前提条件 项目已集成redis
 * Spring Boot 应用启动时扫描到 CacheConfig 类
 * 检测到 @Configuration 注解,将其注册为配置类
 * 检测到 @EnableCaching 注解,启用缓存基础设施
 * 初始化 CacheManager Bean 并配置 Redis 连接
java 复制代码
  @Configuration
  @EnableCaching
  public class CacheConfig {

       @Bean
       public CacheManager cacheManager(RedisConnectionFactory redisConnectionFactory) {
           RedisCacheManager cacheManager = RedisCacheManager.builder(redisConnectionFactory)
               .cacheDefaults(RedisCacheConfiguration.defaultCacheConfig())
              .build();
           return cacheManager;
       }
   }
   PS:
    *     //@Component 用于标注类,表示该类为Spring中的bean组件
    *     //@Bean 用于标注方法,表示这个方法返回的bean对象会被Spring管理,通常在配置类中使用,配合@Configuration注解
相关推荐
中年程序员一枚23 分钟前
Springboot使用maven编译报juh-3.2.1.jar缺失
spring boot·maven·jar
韩立学长25 分钟前
基于Springboot建筑物保护可视化系统rk6tni53(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
superman超哥31 分钟前
Rust Link-Time Optimization (LTO):跨边界的全局优化艺术
开发语言·后端·rust·lto·link-time·跨边界·优化艺术
superman超哥32 分钟前
Rust 编译优化选项配置:释放性能潜力的精细调控
开发语言·后端·rust·rust编译优化·精细调控·编译优化选项
UrbanJazzerati36 分钟前
深度解析Salesforce Apex的Governance Limit:SOQL 50,000条记录的事务级限制
后端·面试
kkkkkkkkl2437 分钟前
从 ACK 到事务裁决:Spring Boot 中 RocketMQ 事务消息的完整工作机制解析
spring boot·rocketmq·java-rocketmq
To Be Clean Coder43 分钟前
【Spring源码】getBean源码实战(一)
java·后端·spring
巴塞罗那的风43 分钟前
golang协程泄漏排查实战
开发语言·后端·golang
quant_19861 小时前
BTC 行情预警系统实战教程
开发语言·后端·python·websocket·程序人生·金融
程序帝国1 小时前
配合上一个文章
spring boot