优化Cache工具类

v1.4.1
Parker 4 years ago
parent d15c66c1fe
commit ab3b990841

@ -55,7 +55,7 @@ public class CacheUtil {
* *
* @param key * @param key
* @param vClass * @param vClass
* @return * @return V
*/ */
public static <V> V get(String key, Class<V> vClass){ public static <V> V get(String key, Class<V> vClass){
return CacheUtil.get(CacheConstants.HOT_DATA,key,vClass,true); return CacheUtil.get(CacheConstants.HOT_DATA,key,vClass,true);
@ -68,7 +68,7 @@ public class CacheUtil {
* *
* @param key * @param key
* @param vClass * @param vClass
* @return * @return V
*/ */
public static <V> V getByKeyOriginal(String key, Class<V> vClass){ public static <V> V getByKeyOriginal(String key, Class<V> vClass){
return CacheUtil.get(CacheConstants.HOT_DATA,key,vClass,false); return CacheUtil.get(CacheConstants.HOT_DATA,key,vClass,false);
@ -103,56 +103,104 @@ public class CacheUtil {
return v; return v;
} }
// ========================= PUT - 热点区 =========================
/** /**
* * -
* *
* *
*
* @param key * @param key
* @param value * @param value
* @return * @return boolean
*/ */
public static boolean put(String key, Object value) { public static boolean put(String key, Object value) {
return CacheUtil.put(key, value, null); return CacheUtil.put(CacheConstants.HOT_DATA, key, value, null, true, true);
} }
private static boolean put(String key, Object value,Integer timeout) {
boolean ret = false;
try { /**
// 如果缓存失效时间设置为空 则默认使用系统配置时间 * -
// 对于Redis缓存定位为远程缓存同步库 当EhCache缓存失效时Redis可以起到抗一波的作用 * Key
// 所以,为了防止缓存雪崩 让Redis的失效时间 = EhCache热数据失效时间*1.2 ~ 2 倍之间随机 * Key opsli:hotData:ahdjksahjkd1
if(timeout == null){ *
timeout = RandomUtils.nextInt( * @param key
Double.valueOf(String.valueOf(ttlHotData * 1.2)).intValue(), * @param value
Double.valueOf(String.valueOf(ttlHotData * 2)).intValue()); * @return boolean
} */
// 存入EhCache public static boolean putByKeyOriginal(String key, Object value){
ehCachePlugin.put(CacheConstants.HOT_DATA,key, value); return CacheUtil.put(CacheConstants.HOT_DATA, key, value, null, true, false);
// 存入Redis
redisPlugin.put(key, value, timeout);
ret = true;
}catch (Exception e){
log.error(e.getMessage(),e);
}
return ret;
} }
// ========================= PUT - 永久代 =========================
/** /**
* * -
* RedisEhCache * RedisEhCache
* Redis * Redis
* *
* @param key * @param key
* @param value * @param value
* @return * @return boolean
*/ */
@Deprecated @Deprecated
public static boolean putByEden(String key, Object value) { public static boolean putEden(String key, Object value) {
return CacheUtil.put(CacheConstants.EDEN_DATA, key, value, null, false, true);
}
/**
* -
* RedisEhCache
* Redis
*
* @param key
* @param value
* @return boolean
*/
@Deprecated
public static boolean putEdenByKeyOriginal(String key, Object value) {
return CacheUtil.put(CacheConstants.EDEN_DATA, key, value, null, false, false);
}
private static boolean put(String cacheName, String key, Object value,Integer timeout, boolean timeFlag, boolean keyFlag) {
boolean ret = false; boolean ret = false;
try { try {
// 自动处理 key
if(keyFlag){
StringBuilder keyBuf = new StringBuilder(CacheDataAop.PREFIX_NAME);
keyBuf.append(cacheName).append(":");
keyBuf.append(key);
key = keyBuf.toString();
}
// 如果不是 JSONObject 则统一转换为 JSONObject
if(!(value instanceof JSONObject)){
String jsonStr = JSONObject.toJSONString(value);
value = JSONObject.parseObject(jsonStr);
}
// 存入EhCache // 存入EhCache
ehCachePlugin.put(CacheConstants.EDEN_DATA,key, value); ehCachePlugin.put(CacheConstants.HOT_DATA,key, value);
// 存入Redis
redisPlugin.put(key, value); if(timeFlag){
// 如果缓存失效时间设置为空 则默认使用系统配置时间
// 对于Redis缓存定位为远程缓存同步库 当EhCache缓存失效时Redis可以起到抗一波的作用
// 所以,为了防止缓存雪崩 让Redis的失效时间 = EhCache热数据失效时间*1.2 ~ 2 倍之间随机
if(timeout == null){
timeout = RandomUtils.nextInt(
Double.valueOf(String.valueOf(ttlHotData * 1.2)).intValue(),
Double.valueOf(String.valueOf(ttlHotData * 2)).intValue());
}
// 存入Redis
redisPlugin.put(key, value, timeout);
}else {
// 存入Redis
redisPlugin.put(key, value);
}
ret = true; ret = true;
}catch (Exception e){ }catch (Exception e){
log.error(e.getMessage(),e); log.error(e.getMessage(),e);
@ -160,11 +208,14 @@ public class CacheUtil {
return ret; return ret;
} }
// ========================= DEL - 删除 =========================
/** /**
* *
* *
* @param key * @param key
* @return * @return boolean
*/ */
public static boolean del(String key) { public static boolean del(String key) {
boolean ret = false; boolean ret = false;
@ -180,6 +231,14 @@ public class CacheUtil {
return ret; return ret;
} }
// ==================================================================== // ====================================================================
/** /**

Loading…
Cancel
Save