spring boot项目实战:分布式锁

本文介绍了在Spring Boot项目中如何实现分布式锁,通过Redis的setnx和getset命令确保操作同步。主要涉及DistributedLock接口、JedisLock实现及DistributedLockUtil工具类。并提醒注意时钟一致性、Redis高可用和锁的替代方案。
摘要由CSDN通过智能技术生成

在部分情况下,要保证操作在整个集群内是同步的,以操作库存为例,多个减操作需要同步,常见的有两种方式:
1. 采用类CAS的方式,先查询库存,然后使用update xxx set num=num-1 where num=:num;这样可保证库在本次修改之前未被修改;
2. 使用分布式锁,保证同时只有一个地方在修改库存。

这里向大家展示一个基于redis的分布式锁。主要涉及三个类:
1. DistributedLockUtil对外提供获取分布式锁的方法;
2. DistributedLock 分布式锁接口,定义分布式锁支持的方法,主要有acquire和release;
3. JedisLock实现DistributedLock接口,是基于redis的分布锁实现 ;

需要使用StringRedisTemplate,如对spring boot整合redis不熟悉,请参考spring boot项目实战:redis.

DistributedLock接口

public interface DistributedLock {

    /**
     * 获取锁
     * @author yangwenkui
     * @time 2016年5月6日 上午11:02:54
     * @return
     * @throws InterruptedException
     */
    public boolean acquire();

    /**
     * 释放锁
     * @author yangwenkui
     * @time 2016年5月6日 上午11:02:59
     */
    public void release();

}

JedisLock基于redis的分布式锁实现

public class JedisLock implements DistributedLock{

    private static Logger logger = LoggerFactory.getLogger(JedisLock.class);

    private static StringRedisTemplate redisTemplate;

    /**
     * 分布式锁的键值
     */
    String lockKey; //锁的键值
    int expireMsecs  = 10 * 1000; //锁超时,防止线程在入锁以后,无限的执行等待
    int     timeoutMsecs = 10 * 1000; //锁等待,防止线程饥饿
    boolean locked = false; //是否已经获取锁

    /**
     * 获取指定键值的锁
     * 
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值