发现一个好用的 spring 项目缓存注解

312 天前
 trifolium2wang

tutu-cache 是为了解决 SpringCache 缓存注解不够灵活的问题而做的 SpringAop 项目。使用 tutu-cache 注解来代替 @Cacheable 和 @CacheEvict 等注解

开源地址: https://github.com/trifolium-x/tutu-cache

文档地址:tutu-cache doc

快速开始

  1. 在 springBoot 中的使用

    • 引入 jar 依赖包

      
      <dependencies>
      
        <dependency>
      
            <groupId>co.tunan.tucache</groupId>
      
            <artifactId>tucache-spring-boot-starter</artifactId>
      
            <version>1.0.4.RELEASE</version>
      
        </dependency>
      
        <!-- 建议使用 redis 或者直接忽略使用本地缓存 -->
      
        <dependency>
      
            <groupId>org.springframework.boot</groupId>
      
            <artifactId>spring-boot-starter-data-redis</artifactId>
      
        </dependency>
      
      </dependencies>
      
        <!-- 或者其他缓存 -->
      
      

使用 tu-cache

  1. 使用 tu-cache 对 service 中的方法返回的数据进行缓存

    
    @TuCache("test_service:getList")
    
    public List<String> getList(){
    
        return Arrays.asList("tu","nan");
    
    }
    
    
  2. 使用 tu-cache 删除缓存中的数据

    
    @TuCacheClear("test_service:getList")
    
    public void delList(){
    
    }
    
    
  3. @TuCache 参数

    • String key() default "" 缓存的字符串格式 key,支持 spEl 表达式(使用#{}包裹 spEl 表达式),默认值为方法签名

    • long expire() default -1 缓存的过期时间,单位(秒),默认永不过期. (在 1.0.4.RELEASE 以上版本中建议使用 timeout)

    • boolean resetExpire() default false 每次获取数据是否重置过期时间.

    • TimeUnit timeUnit() default TimeUnit.SECONDS 缓存的时间单位.

    • String condition() default "true" 扩展的条件过滤,值为 spEl 表达式(直接编写表达式不需要使用#{}方式声明为 spEl)

    • 样例:

      
      @TuCache(key="test_service:getList:#{#endStr}", timeout = 10, timeUnit=TimeUnit.SECONDS)
      
      public List<String> getList(String endStr){
      
          return Arrays.asList("tu","nan",endStr);
      
      }
      
      // 如果需要当前对象的的方法
      
      @TuCache(key="test_service:getList:#{#this.endStr()}", timeout = 120)
      
      public List<String> getList(){
      
          return Arrays.asList("tu","nan",endStr());
      
      }
      
      // 使用 springBean, (使用安全访问符号?.,可以规避 null 错误,具体用法请查看 spEl 表达式)
      
      @TuCache(key="test_service:getList:#{@springBean.endStr()}", timeout = 120)
      
      public List<String> springBeanGetList(){
      
          return Arrays.asList("tu","nan",springBean.endStr());
      
      }
      
      // 使用 condition,当 name 的长度>=5 时进行缓存
      
      @TuCache(key="test_service:getList:#{#name}", condition="#name.length() >= 5")
      
      public List<String> springBeanGetList(String name){
      
          return Arrays.asList("tu","nan",name);
      
      }
      
      public String endStr(){
      
        return "end";
      
      }
      
      
  4. @TuCacheClear 参数

    • String[] key() default {} 删除的 key 数组,支持 spEl 表达式(使用#{}包裹 spEl 表达式)

    • String[] keys() default {} 模糊删除的缓存 key 数组,支持 spEl 表达式(使用#{}包裹 spEl 表达式),对应 redis 中deleteKeys("test_service:")

    • boolean async() default false 是否异步删除,无需等待删除的结果

    • String condition() default "true" 扩展的条件过滤,值为 spEl 表达式(直接编写表达式不需要使用#{}方式声明为 spEl)

    • 样例:

      
      @TuCacheClear(key={"test_service:itemDetail:#{#id}"})
      
      public void deleteItem(Long id){
      
      }
      
      // 如果需要调用本地的方法
      
      @TuCacheClear(keys={"test_service:itemList:","test_service:itemDetail:#{#id}"}, async = true)
      
      public void deleteItem(Long id){
      
      }
      
      
    • 注意 key 和 keys 的区别

  5. condition 的用法

    • condition 要求 spEL 返回一个 boolean 类型的值,例如:

      • condition = "#param.startsWith('a')"

      • condition = "false"

个性化设置

1833 次点击
所在节点    推广
14 条回复
monkeyWie
312 天前
没看出来解决了什么痛点
diagnostics
312 天前
哥们,你是失忆了吗?这不是你自己写的项目吗?
diagnostics
312 天前
没想到 2024 了,还能看到 spring boot 里面使用 xml 配置 bean
Martens
312 天前
推广
28Sv0ngQfIE7Yloe
312 天前
>>> tutu-cache 是为了解决 SpringCache 缓存注解不够灵活的问题而做的 SpringAop 项目

举个例子呗,在那些场景下使用你这个框架更适合啊?
Qlccks2
312 天前
推广就推广,少一点套路。
superbai
312 天前
@Livid 推广引流
wanniwa
312 天前
要是能放点 @Cacheable 和 @CacheEvict 等注解使用起来哪里不灵活,这个框架哪里比他更好用的地方就更好了
Aresxue
312 天前
lyxeno
312 天前
过期配置是比 Spring Cache 灵活一点。不过你这个用方法签名作为 key 感觉会比统一的 Cachename 更难维护?
ggfickle123
312 天前
能不能解释下优化了 Spring Cache 的什么痛点呢
heider
312 天前
自己 AOP 封一个。。想怎么扩展怎么扩展 顶多 200 行代码
zuozuomu
312 天前
反而引用了一个个人开发的包,让项目更不稳定了。解决了 spring 比较稳定的痛点是吧?
potatowish
312 天前
要说到灵活,我宁可手写代码操作缓存,也不想加这些注解。实际业务中,设置缓存和移除缓存的粒度并不是在方法级别,要用到缓存注解,还要拆解出单独的函数。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1018373

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX