springboot整合redis实现分布锁

首先在pom.xml中加入需要的redis依赖和缓存依赖



    org.springframework.boot
    spring-boot-starter-data-redis

 

SpringBoot的yml配置文件下增加redis的配置:

spring:
  redis:
    host: 127.0.0.1
    port: 6379
    password: domcj
 

输入你自己Redis服务器的地址,端口和密码,没有密码的就不要password了。


分布式锁
接下来就是讲分布式锁了。 
假设在一个活动中,商品的特价出售,限时秒杀场景。比如双11的。 
通常的做法,有乐观锁和悲观锁 
介绍乐观锁和悲观锁是什么我就不介绍了。 
其实这里的Redis分布式锁也算是一种乐观锁。也就是即使资源被锁了,后来的用户不会被阻塞,而是返回异常/信息给你,告诉你操作(在这里是抢购)不成功。

实现起来很简单。看下面的类:

package com.domcj.myredis.redis.test;

import javax.annotation.Resource;

import org.springframework.data.redis.core.RedisTemplate;

/**
 * @description: !
 * @author: chenjian
 * @date: 2019/03/06 22:33
 */
public class DistributedLock {

   @Resource
   private RedisTemplate redisTemplate; 
   public boolean lock(String key, int expireTime) {
      long currentTime = System.currentTimeMillis() + expireTime;
      String valueStr = String.valueOf(currentTime);
      if (redisTemplate.opsForValue().setIfAbsent(key, valueStr)) {  //对应redis原生setnx操作
         //可以成功设置,也就是key不存在
         return true;
      }
      //判断锁超时 - 防止原来的操作异常,没有运行解锁操作  防止死锁
      String currentValue  = (String) redisTemplate.opsForValue().get(key);
      //如果锁过期
      if (currentValue !=null&&Long.parseLong(currentValue)




 

你可能感兴趣的:(springboot整合redis实现分布锁)