使用Redis SETNX 命令实现分布式锁

本文介绍了一种基于Redis的简易分布式锁实现方法,并通过具体代码示例展示了如何在多台机器上确保同一任务仅由一台机器执行,有效防止了任务并发冲突。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

防止多台机器上的 task 在同一时间一起执行,只要执行一个就可以了



import service.redis.RedisFacade;

/**
 * Author:  heatdeath
 * Date:    2018/4/24
 * Desc:    基于 Redis 实现的简易分布式锁
 */
public class DistributedLockUtil {

    private String redisKey;
    private static RedisFacade redisFacade;

    private static final int IMMEDIATELY_EXPIRED_TIME = 0;
    private static final int EXPIRE_TIME = 9 * 60;

    /**
     * 构造器,需要输入 redisKey
     *
     * @param redisKey the redis key
     * @throws Exception the exception
     */
    public DistributedLockUtil(String redisKey) throws Exception {
        this.redisKey = redisKey;
        redisFacade = RedisFacade.getInstance();
    }

    /**
     * 使用 redis 的 setnx 命令尝试获取锁
     * 如果成功获取,设置过期时间为 6 min,返回 true
     * 如果失败,返回 false
     *
     * @return the boolean
     * @throws Exception the exception
     */
    public Boolean tryLock() throws Exception {
        Boolean flag = redisFacade.setnx(redisKey, String.valueOf(System.currentTimeMillis())) == 1;
        if (flag)
            redisFacade.expire(redisKey, EXPIRE_TIME);
        return flag;
    }

    /**
     * 释放分布式锁,设置 key 的过期时间为 0s
     *
     * @throws Exception the exception
     */
    public void release() throws Exception {
        redisFacade.expire(redisKey, IMMEDIATELY_EXPIRED_TIME);
    }
}
@Service
public class CountlogSendEmailTask {

    @Autowired
    private CountServiceItf countService;

    private static final String REDIS_KEY = DistributedLockConst.LOCK_FOR_COUNT_BACK_LOG_EMAIL_TASK;

    @Scheduled(cron = "0 0 * * *  ?")
    public void countBacklogSendEmail() throws Exception {
        DistributedLockUtil distributedLock = new DistributedLockUtil(REDIS_KEY);
        if (!distributedLock.tryLock())
            return;
        countService.countBacklogSendEmail();
        distributedLock.release();
    }
}

参考资料:

1、 使用Redis SETNX 命令实现分布式锁
https://blog.youkuaiyun.com/lihao21/article/details/49104695

2、 Java Jedis操作Redis示例(三)——setnx/getset实现分布式锁
https://blog.youkuaiyun.com/KingCat666/article/details/77892176

3、Redis 分布式锁的正确实现方式( Java 版 )
http://www.importnew.com/27477.html


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值