redis常用场景之分布式锁
Springboot下集成redis请参考:/m0_37179470/article/details/81219424
可以用于验证前端的重复请求,可以通过redis进行过滤:每次请求将request Ip、参数、接口等hash作为key存储redis(幂等性请求),设置多长时间有效期,然后下次请求过来的时候先在redis中检索有没有这个key,进而验证是不是一定时间内过来的重复提交秒杀系统,基于redis是单线程特征,防止出现数据库“爆破”。
这里用于调度任务时避免多次对数据库操作。
package ;
import ;
import ;
import ;
import ;
/**
* @author lzz
* @description:
* @date 2018/7/31 14:05
*/
@Service
public class RedisLockService {
@Autowired
private StringRedisTemplate redisTemplate;
private final String LOCKVALUE = "lockvalue";
private boolean locked = false;
public synchronized boolean lock(String lockKey){
/*该方法会在没有key时,设置key;存在key时返回false;因此可以通过该方法及设置key的有效期,判断是否有其它线程持有锁*/
Boolean success = ().setIfAbsent(lockKey,LOCKVALUE);
if(success != null && success){
(lockKey,3,);
locked = true;
}else{
locked = false;
}
return locked;
}
}