redis常用场景之分布式锁
Springboot下集成redis请参考:https://blog.csdn.net/m0_37179470/article/details/81219424
可以用于验证前端的重复请求,可以通过redis进行过滤:每次请求将request Ip、参数、接口等hash作为key存储redis(幂等性请求),设置多长时间有效期,然后下次请求过来的时候先在redis中检索有没有这个key,进而验证是不是一定时间内过来的重复提交秒杀系统,基于redis是单线程特征,防止出现数据库“爆破”。
这里用于调度任务时避免多次对数据库操作。
package com.lzz.service;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.stereotype.Service;
import java.util.concurrent.TimeUnit;
/**
* @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 = redisTemplate.opsForValue().setIfAbsent(lockKey,LOCKVALUE);
if(success != null && success){
redisTemplate.expire(lockKey,3,TimeUnit.SECONDS);
locked = true;
}else{
locked = false;
}
return locked;
}
}