com.litongjava.redis.RedisCacheInterceptor Maven / Gradle / Ivy
package com.litongjava.redis;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
import com.litongjava.cache.CacheableModel;
import com.litongjava.jfinal.aop.AopInterceptor;
import com.litongjava.jfinal.aop.AopInvocation;
import redis.clients.jedis.Jedis;
/**
* CacheInterceptor.
*/
public class RedisCacheInterceptor implements AopInterceptor {
private static ConcurrentHashMap lockMap = new ConcurrentHashMap(512);
protected RedisDb getCache() {
return Redis.use();
}
private ReentrantLock getLock(String key) {
ReentrantLock lock = lockMap.get(key);
if (lock != null) {
return lock;
}
lock = new ReentrantLock();
ReentrantLock previousLock = lockMap.putIfAbsent(key, lock);
return previousLock == null ? lock : previousLock;
}
final public void intercept(AopInvocation inv) {
RedisDb cache = getCache();
Jedis jedis = cache.getThreadLocalJedis();
if (jedis != null) {
putIfNotExists(inv, cache, jedis);
}
try {
jedis = cache.jedisPool.getResource();
cache.setThreadLocalJedis(jedis);
putIfNotExists(inv, cache, jedis);
} finally {
cache.removeThreadLocalJedis();
jedis.close();
}
}
private void putIfNotExists(AopInvocation inv, RedisDb cache, Jedis jedis) {
Object target = inv.getTarget();
CacheableModel cacheableModel = CacheableModel.buildCacheModel(inv, target);
String redisKey = cacheableModel.getName() + "_" + cacheableModel.getKey();
String cacheData = cache.get(redisKey);
if (cacheData == null) {
Lock lock = getLock(redisKey);
lock.lock(); // prevent cache snowslide
try {
Object returnValue = inv.invoke();
cacheData = cache.get(redisKey);
if (cacheData == null) {
cache.setex(redisKey, cacheableModel.getTtl(), returnValue);
return;
}
} finally {
lock.unlock();
}
}
// useCacheDataAndReturn(cacheData, target);
inv.setReturnValue(cacheData);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy