基于redis的分布式锁实现,使用redistemplate操作

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;
    }
}

猜你喜欢

转载自blog.csdn.net/m0_37179470/article/details/81449213