【Spring Boot】如何运用Spring Cache并设置缓存失效时间

  1. 简单描述
    1. Spring Cache是一个框架,实现了基于注解的缓存功能,只需要简单地加一个注解,就能实现缓存功能。Spring Cache提供了一层抽象,底层可以切换不同的cache实现。具体就是通过CacheManager接口来统一不同的缓存技术。CacheManager是Spring提供的各种缓存技术抽象接口。
    2. 常用注解
      1. 注解 说明
        @EnableCaching 开启缓存注解功能
        @Cacheable 在方法执行前spring先查看缓存中是否有数据,如果有数据,则直接返回缓存数据;若没有数据,则调用方法并将方法返回值放到缓存中。常用于查询方法
        @CachePut 将方法的返回值放到缓存中。常用于更新缓存
        @CacheEvict

        将一条或多条数据从缓存中删除。常用于失效缓存

  2. 在pom.xml文件中导入Spring Cache和Redis相关maven坐标
    1.         
                  org.springframework.boot
                  spring-boot-starter-data-redis
              
      
              
                  org.springframework.boot
                  spring-boot-starter-cache
              
  3. 在启动类上加入@EnableCaching的缓存注解功能
    1. package com.app.studypro;
      
      import org.springframework.boot.SpringApplication;
      import org.springframework.boot.autoconfigure.SpringBootApplication;
      import org.springframework.boot.web.servlet.ServletComponentScan;
      import org.springframework.cache.annotation.EnableCaching;
      
      /**
       * 启动类
       * 注解@EnableCaching:开启缓存注解功能
       *
       * @author Administrator
       */
      @SpringBootApplication
      @ServletComponentScan
      @EnableCaching
      public class StudyProApplication {
      
          public static void main(String[] args) {
              SpringApplication.run(StudyProApplication.class, args);
          }
      
      }
      
  4. 若需要将数据存入缓存,则缓存对象一定要实现Serializable接口
    1. package com.app.studypro.common;
      
      import lombok.Data;
      
      @Data
      public class ResultBean implements Serializable {
      
          private static final long serialVersionUID = -6759928086797729382L;
      
      
      }
      
  5. 统一归类管理Redis的cacheName缓存失效时间,并设置相应的缓存序列化器
    1. package com.app.studypro.config;
      
      import lombok.extern.slf4j.Slf4j;
      import org.springframework.cache.CacheManager;
      import org.springframework.cache.annotation.CachingConfigurerSupport;
      import org.springframework.context.annotation.Bean;
      import org.springframework.context.annotation.Configuration;
      import org.springframework.data.redis.cache.RedisCacheConfiguration;
      import org.springframework.data.redis.cache.RedisCacheManager;
      import org.springframework.data.redis.connection.RedisConnectionFactory;
      import org.springframework.data.redis.core.RedisTemplate;
      import org.springframework.data.redis.serializer.StringRedisSerializer;
      
      import java.time.Duration;
      import java.util.HashMap;
      import java.util.Map;
      
      /**
       * Redis的配置信息
       *
       * @author Administrator
       */
      @Configuration
      @Slf4j
      public class RedisConfig extends CachingConfigurerSupport {
      
          @Bean
          public RedisTemplate redisTemplate(RedisConnectionFactory connectionFactory) {
              RedisTemplate redisTemplate = new RedisTemplate<>();
              log.info("Redis的KeySerializer设置为:{}", StringRedisSerializer.class);
              // 默认的Key序列化器为:JdkSerializationRedisSerializer
              // 将key的序列化器改为StringRedisSerializer,以便可以在Redis的key设置什么就显示什么,不进行转化
              redisTemplate.setKeySerializer(new StringRedisSerializer());
              redisTemplate.setConnectionFactory(connectionFactory);
              return redisTemplate;
          }
      
          /**
           * 缓存管理
           *
           * @return 返回缓存管理信息
           */
          @Bean
          public CacheManager cacheManager(RedisConnectionFactory redisConnectionFactory) {
              // 缓存配置
              RedisCacheConfiguration defaultCacheConfig = RedisCacheConfiguration.defaultCacheConfig()
                      // 默认没有特殊指定的缓存,设置失效时间为1天
                      .entryTtl(Duration.ofDays(1))
                      // 在缓存名称前加上前缀
                      .computePrefixWith(cacheName -> "default:" + cacheName);
              log.info("设置redis缓存的默认失效时间,失效时间默认为:{}天", defaultCacheConfig.getTtl().toDays());
              // 针对不同cacheName,设置不同的失效时间,map的key是缓存名称(注解设定的value/cacheNames),value是缓存的失效配置
              Map initialCacheConfiguration = new HashMap(8);
              // 设定失效时间为1小时
              initialCacheConfiguration.put("userCache", getDefaultSimpleConfiguration().entryTtl(Duration.ofHours(1)));
              // 设定失效时间为10分钟
              initialCacheConfiguration.put("userCache1", getDefaultSimpleConfiguration().entryTtl(Duration.ofMinutes(10)));
              // 设定失效时间为12小时
              initialCacheConfiguration.put("userCache2", getDefaultSimpleConfiguration().entryTtl(Duration.ofHours(12)));
              // ...如果有其他的不同cacheName需要控制失效时间,以此类推即可进行添加
              return RedisCacheManager.builder(redisConnectionFactory)
                      // 设置缓存默认失效时间配置,也就是动态或者未指定的缓存将会使用当前配置
                      .cacheDefaults(defaultCacheConfig)
                      // 不同不同cacheName的个性化配置
                      .withInitialCacheConfigurations(initialCacheConfiguration).build();
          }
      
          /**
           * 覆盖默认的构造key[默认拼接的时候是两个冒号(::)],否则会多出一个冒号
           *
           * @return 返回缓存配置信息
           */
          private RedisCacheConfiguration getDefaultSimpleConfiguration() {
              return RedisCacheConfiguration.defaultCacheConfig().computePrefixWith(cacheName -> cacheName + ":");
          }
      
      }
      
  6. 在控制器Controller的请求方法上添加相应的注解
    1.     @CachePut(value = "userCache", key = "#result.data.id")
          @PostMapping
          public ResultBean save(HttpServletRequest request, @RequestBody User user) {
        
              return ResultBean.success(user);
          }
    2.     @CacheEvict(value = "userCache", allEntries = true)
          @PutMapping
          public ResultBean update(HttpServletRequest request, @RequestBody User user) {
      
              return ResultBean.success("用户信息修改成功");
          }
    3.     @Cacheable(value = "userCache3", key = "#id")
          @GetMapping("/{id}")
          public ResultBean getById(@PathVariable Long id) {
      
          }
    4.     @GetMapping("/page")
          @Cacheable(value = "userCache", key = "#page+'_'+#pageSize+'_'+#username", unless = "#result.data.total==0")
          public ResultBean> page(int page, int pageSize, String username) {
      
              return ResultBean.success(pageInfo);
          }
  7. 可以在Redis的可视化操作界面上看出不同的cacheName的缓存的失效时间是不一样的,根据配置的设置,不在缓存管理Map中缓存默认失效时间是1天。可视化界面中的TTL单位是秒
    1. 【Spring Boot】如何运用Spring Cache并设置缓存失效时间_第1张图片

你可能感兴趣的:(spring,boot,spring,spring,boot,java,redis)