@Servicepublic classRedisUtil {private static final Long SUCCESS = 1L;
@Autowiredprivate RedisTemplateredisTemplate;/**
* 指定缓存失效时间
*
* @param key 键
* @param time 时间(秒)
* @return*/
public boolean expire(String key, longtime) {try{if (time > 0) {
redisTemplate.expire(key, time, TimeUnit.SECONDS);
}return true;
}catch(Exception e) {return false;
}
}/**
* 根据key 获取过期时间
*
* @param key 键 不能为null
* @return 时间(秒) 返回0代表为永久有效*/
public longgetExpire(String key) {returnredisTemplate.getExpire(key, TimeUnit.SECONDS);
}/**
* 判断key是否存在
*
* @param key 键
* @return true 存在 false不存在*/
publicboolean hasKey(String key) {try{returnredisTemplate.hasKey(key);
}catch(Exception e) {return false;
}
}/**
* 删除缓存
*
* @param key 可以传一个值 或多个*/@SuppressWarnings("unchecked")public voiddel(String... key) {if (key != null && key.length > 0) {if (key.length == 1) {
redisTemplate.delete(key[0]);
}else{
redisTemplate.delete(CollectionUtils.arrayToList(key));
}
}
}/**
* 普通缓存获取
*
* @param key 键
* @return 值*/
public Object get(String key) {return key == null ? null : redisTemplate.opsForValue().get(key);
}/**
* 普通缓存放入
*
* @param key 键
* @param value 值
* @return true成功 false失败*/
public boolean set(String key, Object value) {try{
redisTemplate.opsForValue().set(key, value);return true;
}catch(Exception e) {return false;
}
}/**
* 普通缓存放入并设置时间
*
* @param key 键
* @param value 值
* @param time 时间(秒) time要大于0 如果time小于等于0 将设置无限期
* @return true成功 false 失败*/
public boolean set(String key, Object value, longtime) {try{if (time > 0) {
redisTemplate.opsForValue().set(key, value, time, TimeUnit.SECONDS);
}else{set(key, value);
}return true;
}catch(Exception e) {return false;
}
}/**
* 递增
*
* @param key 键
* @param delta 要增加几(大于0)
* @return*/
public long incr(String key, longdelta) {if (delta < 0) {throw new RuntimeException("递增因子必须大于0");
}returnredisTemplate.opsForValue().increment(key, delta);
}/**
* 递减
*
* @param key 键
* @param delta 要减少几(小于0)
* @return 147*/
public long decr(String key, longdelta) {if (delta < 0) {throw new RuntimeException("递减因子必须大于0");
}return redisTemplate.opsForValue().increment(key, -delta);
}/**
* 获取分布式锁
* @param lockKey 锁
* @param requestId 请求标识
* @param expireTime 单位秒
* @param waitTimeout 单位毫秒
* @return 是否获取成功*/
public boolean tryLock(String lockKey, String requestId, int expireTime,longwaitTimeout) {long nanoTime = System.nanoTime(); //当前时间
try{
String script= "if redis.call('setNx',KEYS[1],ARGV[1]) then if redis.call('get',KEYS[1])==ARGV[1] then return redis.call('expire',KEYS[1],ARGV[2]) else return 0 end end";int count = 0;do{
RedisScript redisScript = new DefaultRedisScript<>(script, String.class);
Object result=redisTemplate.execute(redisScript, Collections.singletonList(lockKey),requestId,expireTime);if(SUCCESS.equals(result)) {return true;
}
Thread.sleep(500L);//休眠500毫秒
count++;
}while ((System.nanoTime() - nanoTime)
}catch(Exception e){
e.printStackTrace();
}return false;
}/**
* 释放锁
* @param lockKey 锁
* @param requestId 请求标识
* @return 是否释放成功*/
publicboolean releaseLock(String lockKey, String requestId) {
String script= "if redis.call('get', KEYS[1]) == ARGV[1] then return redis.call('del', KEYS[1]) else return 0 end";
RedisScript redisScript = new DefaultRedisScript<>(script, String.class);
Object result=redisTemplate.execute(redisScript, Collections.singletonList(lockKey), requestId);if(SUCCESS.equals(result)) {return true;
}return false;
}
}