Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/trifolium-x/tutu-cache

tu-cache is an annotation-based caching tool for Spring, designed to address the limitations of Spring's caching annotations.
https://github.com/trifolium-x/tutu-cache

annotation-tool cache redis spring-boot spring-cache spring-cache-redis tu-cache

Last synced: 7 days ago
JSON representation

tu-cache is an annotation-based caching tool for Spring, designed to address the limitations of Spring's caching annotations.

Awesome Lists containing this project

README

        

![tutu-cache](https://socialify.git.ci/trifolium-x/tutu-cache/image?description=1&font=Inter&forks=1&issues=1&language=1&name=1&owner=1&pattern=Circuit%20Board&pulls=1&stargazers=1&theme=Light)
tutu-cache 是一个简单易用的Spring缓存注解。


使用tutu-cache注解来代替@Cacheable和@CacheEvict等注解

[![GitHub license](https://img.shields.io/github/license/trifolium-x/tutu-cache)](https://github.com/trifolium-x/tutu-cache/blob/master/LICENSE)
[![RELEASE](https://img.shields.io/badge/RELEASE-1.0.4.RELEASE-blue)](https://github.com/trifolium-x/tutu-cache/releases/tag/1.0.4.RELEASE)

### Version
* 1.0.4.RELEASE
* 1.0.3.RELEASE
* 1.0.2.RELEASE
* 1.0.1.RELEASE
* 1.0.0

### 🥳Quick Start
1. 在springBoot中的使用
* 引入jar依赖包
```xml


co.tunan.tucache
tucache-spring-boot-starter
1.0.4.RELEASE



org.springframework.boot
spring-boot-starter-data-redis


```
### 使用tu-cache
1. 使用tu-cache对service中的方法返回的数据进行缓存
```java
@TuCache("test_service:getList")
public List getList(){
return Arrays.asList("tu","nan");
}
```
2. 使用tu-cache删除缓存中的数据
```java
@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)
* 样例:
```java
@TuCache(key="test_service:getList:#{#endStr}", timeout = 10, timeUnit=TimeUnit.SECONDS)
public List getList(String endStr){
return Arrays.asList("tu","nan",endStr);
}

// 如果需要当前对象的的方法
@TuCache(key="test_service:getList:#{#this.endStr()}", timeout = 120)
public List getList(){
return Arrays.asList("tu","nan",endStr());
}

// 使用springBean, (使用安全访问符号?.,可以规避null错误,具体用法请查看spEl表达式)
@TuCache(key="test_service:getList:#{@springBean.endStr()}", timeout = 120)
public List springBeanGetList(){
return Arrays.asList("tu","nan",springBean.endStr());
}

// 使用condition,当name的长度>=5时进行缓存
@TuCache(key="test_service:getList:#{#name}", condition="#name.length() >= 5")
public List 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)
* 样例:
```java
@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"

* 建议自定义序列化在Configure类中注册javaBean redisTemplate或者使用默认的redisTemplate,必须开启aspectj的aop功能(默认是开启的)
```java
@Bean(name = "redisTemplate")
public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory) {
RedisTemplate redisTemplate = new RedisTemplate<>();
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());
redisTemplate.setConnectionFactory(redisConnectionFactory);

return redisTemplate;
}
```
### 版本对应的spring基础环境版本
* 建议springBoot版本在2.1.x-2.7.x,目前兼容springBoot3
* tucache 1.0.4.RELEASE ----- spring 5.3.29 ----- springBoot版本2.6.17
* tucache 1.0.3.RELEASE ----- spring 5.3.15 ----- springBoot版本2.6.3
* tucache 1.0.2.RELEASE ----- spring 5.1.3.RELEASE ----- springBoot版本2.1.1.RELEASE
* tucache 1.0.1.RELEASE ----- spring 5.1.3.RELEASE ----- springBoot版本2.1.1.RELEASE
### 个性化设置
* tutu-cache默认提供了 RedisTuCacheService,如果用户使用的缓存是redis并配置了redisTemplate的bean则自动使用该默认缓存服务。
* 用户使用其他缓存,则需要自定义TuCacheService,实现该接口并注入到TuCacheBean中
* 在SpringBoot中在Configure类中配置相应的bean自动使用自定义的bean
* 如果用户需要每个缓存前面添加同意的keyPrefix,TuCacheBean的prefixKey参数
* springBoot中配置
```yaml
tucache:
enabled: true
cache-type: redis
profiles:
cache-prefix: "my_tu_key_test:"
# ...
```
* springMVC中注入到TuCacheBean
```xml



```
```xml




```
* 关于默认RedisTuCacheService的序列化问题,强烈建议使用对key使用String方式序列化
* 使用Json序列化配置样例如下:
```java
@Bean(name = "redisTemplate")
public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory) {
RedisTemplate redisTemplate = new RedisTemplate<>();
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setHashKeySerializer(new StringRedisSerializer());
redisTemplate.setHashValueSerializer(new GenericJackson2JsonRedisSerializer(createGenericObjectMapper()));
redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer(createGenericObjectMapper()));

redisTemplate.setConnectionFactory(redisConnectionFactory);

return redisTemplate;
}
```

#### 作者QQ 交流群: 76131683
#### 希望更多的开发者参与
☕️[请我喝一杯咖啡]
* ↓↓↓ 微信扫码 ↓↓↓

赞赏码

### 打赏列表
| 昵称(按时间顺序) | 金额 |
|-----------|----|
| 一直在梦想路上 | 20 |
| | |
| | |

### [感谢JetBrains提供的免费授权](https://www.jetbrains.com/?from=tutu-cache)
[![JetBrains logo](assets/thanks/jetbrains.svg)](https://www.jetbrains.com/?from=tutu-cache)