项目中经常可能需要用到本地缓存来提高效率,自己写缓存又太麻烦,而且还有内存溢出的问题。本工具类是通过goole的开源框架Guava来实现的本地缓存,使用方式很简单,可以自己进行扩展。当缓存达到最大值时,会自动根据lru算法对数据进行淘汰。
package com.jd.crius.cache.local;
import com.google.common.cache.CacheBuilder;
import com.google.common.cache.CacheLoader;
import com.google.common.cache.LoadingCache;
import com.jd.crius.cache.redis.RedisCache;
import com.jd.data.redis.connection.RedisAccessException;
import java.util.Map;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.TimeUnit;
/**
* 本地缓存操作工具类
* User: caozhifei
* Date: 15-3-26
* Time: 下午4:09
* To change this template use File | Settings | File Templates.
*/
public class LocalCacheUtil {
/**
* redis缓存操作对象
*/
private RedisCache redisCache;
/**
* 本地缓存对象
*/
private LoadingCache<String, Map<String, String>> LOCAL_CACHE_MAP = CacheBuilder
.newBuilder().softValues()
.maximumSize(20000).expireAfterAccess(2, TimeUnit.MINUTES) //maximumSize表示可以保存的key的最大数量;expireAfterAccess表示过期时间
.build(new CacheLoader<String, Map<String, String>>() {
@Override
public Map<String, String> load(String key) throws Exception {
//通过key获取本地缓存数据为空时,从新load远程redis数据到本地缓存
Map<String, String> map = redisCache.getKeyMap(key);
if(map == null){
//redis中取得数据也为空时 ,具体操作
}
return map;
}
});
/**
* 设置本地缓存
*
* @param key
* @param map
*/
public void setKeyMap(String key, Map<String, String> map) throws RedisAccessException {
LOCAL_CACHE_MAP.put(key, map);//设置本地缓存
redisCache.setKeyMap(key, map); //设置远程redis缓存
}
/**
* 通过key查询本地缓存数据
*
* @param key
* @return
* @throws ExecutionException
*/
public Map<String, String> getKeyMap(String key) throws ExecutionException {
Map<String, String> map = LOCAL_CACHE_MAP.get(key);
return map;
}
}