介绍
缓存数据库领域的门面框架,类似于日志框架里的slf4j。你能用它做什么呢?不需要修改任何代码就可以快速的切换缓存数据库,同时,支持基于注解的切面缓存。github地址:https://github.com/xiaoyudeguang/easy-cache
Maven引用(最新版本)
<dependency>
<groupId>io.github.xiaoyudeguang</groupId>
<artifactId>easy-cache</artifactId>
<version>最新版本</version>
</dependency>
切面缓存功能
(1)添加缓存
@EasyCache(key = "name", todo = "")
public int doService(String name) {
return this.hascode();
}
请注意,你的方法参数中一定得有一个参数的参数名和@EasyCache注解的key值一样,不然缓存是不会生效的。那个参数可以直接存在于方法参数中(位置无所谓),也可以存在于某个map(Map实现类)中。
(2)更新缓存
@EasyCache(value = Operation.SAVE, key = "name", todo = "")
public int delete(String name) {
return this.hascode();
}
(3)删除缓存
CacheUtils.remove(key);
切换缓存功能
CacheUtils默认使用ConcurrentHashMap来作为缓存。你可以根据需要来切换缓存。由于使用了自动配置,你只需要引入对应的jar包即可。
(1)切换到Redis数据库:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
(2)切换到Memcached数据库。
<dependency>
<groupId>net.spy</groupId>
<artifactId>spymemcached</artifactId>
<version>2.12.2</version>
</dependency>
如果memcached不是在本地,需要在application.properties文件中增加memcached配置:
memcache.host=127.0.0.1 memcache.port=11211
扩展功能
如果需要扩展到别的缓存数据库,只需要实现Cache接口即可,以Redis为例:
package com.zlyx.easy.cache.cache;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import com.zlyx.easy.core.cache.Cache;
/**
* @Auth 赵光
* @Describle
* @2019年9月9日
*/
public class RedisCache implements Cache {
@Autowired
private RedisTemplate<String, Object> redisTemplate;
@Override
public void set(String key, Object value) {
redisTemplate.opsForValue().set(key, value);
}
@Override
public boolean containsKey(String key) {
return redisTemplate.opsForValue().get(key) != null;
}
@Override
public Object remove(String key) {
Object value = get(key);
redisTemplate.delete(key);
return value;
}
@Override
public Object get(String key) {
return redisTemplate.opsForValue().get(key);
}
@Override
public void clear() {
throw new UnsupportedOperationException("RedisCache不支持clear操作");
}
}