| | |
| | | package com.ruoyi.demo.controller; |
| | | |
| | | import com.ruoyi.common.core.domain.AjaxResult; |
| | | import com.ruoyi.common.core.domain.R; |
| | | import com.ruoyi.common.utils.redis.RedisUtils; |
| | | import io.swagger.v3.oas.annotations.Operation; |
| | | import io.swagger.v3.oas.annotations.tags.Tag; |
| | | import lombok.RequiredArgsConstructor; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.cache.annotation.CacheEvict; |
| | | import org.springframework.cache.annotation.CachePut; |
| | | import org.springframework.cache.annotation.Cacheable; |
| | | import org.springframework.web.bind.annotation.GetMapping; |
| | | import org.springframework.web.bind.annotation.RequestMapping; |
| | | import org.springframework.web.bind.annotation.RestController; |
| | | |
| | | import java.time.Duration; |
| | | |
| | | /** |
| | | * spring-cache 演示案例 |
| | |
| | | */ |
| | | // 类级别 缓存统一配置 |
| | | //@CacheConfig(cacheNames = "redissonCacheMap") |
| | | @RequiredArgsConstructor(onConstructor_ = @Autowired) |
| | | @Tag(name ="spring-cache 演示案例", description = "spring-cache 演示案例") |
| | | @RequiredArgsConstructor |
| | | @RestController |
| | | @RequestMapping("/demo/cache") |
| | | public class RedisCacheController { |
| | | |
| | | /** |
| | | * 测试 @Cacheable |
| | | * |
| | | * 表示这个方法有了缓存的功能,方法的返回值会被缓存下来 |
| | | * 下一次调用该方法前,会去检查是否缓存中已经有值 |
| | | * 如果有就直接返回,不调用方法 |
| | | * 如果没有,就调用方法,然后把结果缓存起来 |
| | | * 这个注解「一般用在查询方法上」 |
| | | * |
| | | * cacheNames 为配置文件内 groupId |
| | | */ |
| | | @Cacheable(cacheNames = "redissonCacheMap", key = "#key", condition = "#key != null") |
| | | @GetMapping("/test1") |
| | | public AjaxResult<String> test1(String key, String value){ |
| | | return AjaxResult.success("操作成功", value); |
| | | } |
| | | /** |
| | | * 测试 @Cacheable |
| | | * <p> |
| | | * 表示这个方法有了缓存的功能,方法的返回值会被缓存下来 |
| | | * 下一次调用该方法前,会去检查是否缓存中已经有值 |
| | | * 如果有就直接返回,不调用方法 |
| | | * 如果没有,就调用方法,然后把结果缓存起来 |
| | | * 这个注解「一般用在查询方法上」 |
| | | * <p> |
| | | * 重点说明: 缓存注解严谨与其他筛选数据功能一起使用 |
| | | * 例如: 数据权限注解 会造成 缓存击穿 与 数据不一致问题 |
| | | * <p> |
| | | * cacheNames 为配置文件内 groupId |
| | | */ |
| | | @Cacheable(cacheNames = "redissonCacheMap", key = "#key", condition = "#key != null") |
| | | @GetMapping("/test1") |
| | | public R<String> test1(String key, String value) { |
| | | return R.ok("操作成功", value); |
| | | } |
| | | |
| | | /** |
| | | * 测试 @CachePut |
| | | * |
| | | * 加了@CachePut注解的方法,会把方法的返回值put到缓存里面缓存起来,供其它地方使用 |
| | | * 它「通常用在新增方法上」 |
| | | * |
| | | * cacheNames 为 配置文件内 groupId |
| | | */ |
| | | @CachePut(cacheNames = "redissonCacheMap", key = "#key", condition = "#key != null") |
| | | @GetMapping("/test2") |
| | | public AjaxResult<String> test2(String key, String value){ |
| | | return AjaxResult.success("操作成功", value); |
| | | } |
| | | /** |
| | | * 测试 @CachePut |
| | | * <p> |
| | | * 加了@CachePut注解的方法,会把方法的返回值put到缓存里面缓存起来,供其它地方使用 |
| | | * 它「通常用在新增方法上」 |
| | | * <p> |
| | | * cacheNames 为 配置文件内 groupId |
| | | */ |
| | | @CachePut(cacheNames = "redissonCacheMap", key = "#key", condition = "#key != null") |
| | | @GetMapping("/test2") |
| | | public R<String> test2(String key, String value) { |
| | | return R.ok("操作成功", value); |
| | | } |
| | | |
| | | /** |
| | | * 测试 @CacheEvict |
| | | * |
| | | * 使用了CacheEvict注解的方法,会清空指定缓存 |
| | | * 「一般用在更新或者删除的方法上」 |
| | | * |
| | | * cacheNames 为 配置文件内 groupId |
| | | */ |
| | | @CacheEvict(cacheNames = "redissonCacheMap", key = "#key", condition = "#key != null") |
| | | @GetMapping("/test3") |
| | | public AjaxResult<String> test3(String key, String value){ |
| | | return AjaxResult.success("操作成功", value); |
| | | } |
| | | /** |
| | | * 测试 @CacheEvict |
| | | * <p> |
| | | * 使用了CacheEvict注解的方法,会清空指定缓存 |
| | | * 「一般用在更新或者删除的方法上」 |
| | | * <p> |
| | | * cacheNames 为 配置文件内 groupId |
| | | */ |
| | | @CacheEvict(cacheNames = "redissonCacheMap", key = "#key", condition = "#key != null") |
| | | @GetMapping("/test3") |
| | | public R<String> test3(String key, String value) { |
| | | return R.ok("操作成功", value); |
| | | } |
| | | |
| | | /** |
| | | * 测试设置过期时间 |
| | | * 手动设置过期时间10秒 |
| | | * 11秒后获取 判断是否相等 |
| | | */ |
| | | @GetMapping("/test6") |
| | | public R<Boolean> test6(String key, String value) { |
| | | RedisUtils.setCacheObject(key, value); |
| | | boolean flag = RedisUtils.expire(key, Duration.ofSeconds(10)); |
| | | System.out.println("***********" + flag); |
| | | try { |
| | | Thread.sleep(11 * 1000); |
| | | } catch (InterruptedException e) { |
| | | e.printStackTrace(); |
| | | } |
| | | Object obj = RedisUtils.getCacheObject(key); |
| | | return R.ok(value.equals(obj)); |
| | | } |
| | | |
| | | } |