java实现分布式锁

简介: 分布式锁:满足分布式系统或集群模式下多进程可见并且互斥的锁。

分布式锁:满足分布式系统或集群模式下多进程可见并且互斥的锁。

跨机器进程间数据同步问题


我们用第三种 悲观锁

加入依赖

        <!-- redis分布式锁 -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>lock4j-redisson-spring-boot-starter</artifactId>
            <version>2.2.2</version>
        </dependency>

核心代码

package com.study.task;
import com.baomidou.lock.LockInfo;
import com.baomidou.lock.LockTemplate;
import com.baomidou.lock.executor.RedissonLockExecutor;
import com.fasterxml.jackson.databind.ObjectMapper;
import lombok.extern.slf4j.Slf4j;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
import javax.annotation.Resource;
import java.util.UUID;
@Component
@Slf4j
@EnableScheduling
public class ProductTask {
    @Resource
    private LockTemplate lockTemplate;
    @Scheduled(cron = "0/1 0/5 * * * ?")
    public void productTackStart() {
        //get lock
        LockInfo lockInfo = null;
        try {
            String key = UUID.randomUUID() + "";
            log.info("开始加锁------------key:{}", key);
            lockInfo = lockTemplate.lock(key, 5000L, 100L, RedissonLockExecutor.class);
            //对象转json,可以在使用任意一种方法,google/mybatis/alibaba都有封装
            ObjectMapper Obj = new ObjectMapper();
            String jsonStr = Obj.writeValueAsString(lockInfo);
            log.info("lockInfo:{}", jsonStr);
            log.info("定时任务开始-------");
            //业务代码入口
        } catch (Exception e) {
            log.error("异常:", e);
        } finally {
            //解锁
            if (null == lockInfo) {
                log.info("--------lockInfo is null");
                return;
            }
            boolean releaseLock = lockTemplate.releaseLock(lockInfo);
            log.info("-----releaseLock:{}", releaseLock);
        }
    }
}

简化版

//get lock
            LockInfo lockInfo = null;
            try {
                lockInfo = this.lockTemplate.lock(BRAND_KEY_LOCK, 5000L, 0L,
                        RedissonLockExecutor.class);#BRAND_KEY_LOCK定义为唯一的key
                //业务
                Integer updateBrand = this.updateBrand(brandPageReq, now, mchBrand);
                log.info("updateBrand:{}", updateBrand);
            } catch (Exception e) {
                log.error("修改品牌:", e);
            } finally {
                this.lockTemplate.releaseLock(lockInfo);
            }
相关文章
|
人工智能 安全 Java
智慧工地源码,Java语言开发,微服务架构,支持分布式和集群部署,多端覆盖
智慧工地是“互联网+建筑工地”的创新模式,基于物联网、移动互联网、BIM、大数据、人工智能等技术,实现对施工现场人员、设备、材料、安全等环节的智能化管理。其解决方案涵盖数据大屏、移动APP和PC管理端,采用高性能Java微服务架构,支持分布式与集群部署,结合Redis、消息队列等技术确保系统稳定高效。通过大数据驱动决策、物联网实时监测预警及AI智能视频监控,消除数据孤岛,提升项目可控性与安全性。智慧工地提供专家级远程管理服务,助力施工质量和安全管理升级,同时依托可扩展平台、多端应用和丰富设备接口,满足多样化需求,推动建筑行业数字化转型。
439 5
|
存储 缓存 Java
Java中的分布式缓存与Memcached集成实战
通过在Java项目中集成Memcached,可以显著提升系统的性能和响应速度。合理的缓存策略、分布式架构设计和异常处理机制是实现高效缓存的关键。希望本文提供的实战示例和优化建议能够帮助开发者更好地应用Memcached,实现高性能的分布式缓存解决方案。
307 9
|
存储 分布式计算 Hadoop
基于Java的Hadoop文件处理系统:高效分布式数据解析与存储
本文介绍了如何借鉴Hadoop的设计思想,使用Java实现其核心功能MapReduce,解决海量数据处理问题。通过类比图书馆管理系统,详细解释了Hadoop的两大组件:HDFS(分布式文件系统)和MapReduce(分布式计算模型)。具体实现了单词统计任务,并扩展支持CSV和JSON格式的数据解析。为了提升性能,引入了Combiner减少中间数据传输,以及自定义Partitioner解决数据倾斜问题。最后总结了Hadoop在大数据处理中的重要性,鼓励Java开发者学习Hadoop以拓展技术边界。
568 7
|
Java 数据库
在Java中使用Seata框架实现分布式事务的详细步骤
通过以上步骤,利用 Seata 框架可以实现较为简单的分布式事务处理。在实际应用中,还需要根据具体业务需求进行更详细的配置和处理。同时,要注意处理各种异常情况,以确保分布式事务的正确执行。
|
消息中间件 Java Kafka
在Java中实现分布式事务的常用框架和方法
总之,选择合适的分布式事务框架和方法需要综合考虑业务需求、性能、复杂度等因素。不同的框架和方法都有其特点和适用场景,需要根据具体情况进行评估和选择。同时,随着技术的不断发展,分布式事务的解决方案也在不断更新和完善,以更好地满足业务的需求。你还可以进一步深入研究和了解这些框架和方法,以便在实际应用中更好地实现分布式事务管理。
1319 161
|
存储 NoSQL Java
Java调度任务如何使用分布式锁保证相同任务在一个周期里只执行一次?
【10月更文挑战第29天】Java调度任务如何使用分布式锁保证相同任务在一个周期里只执行一次?
596 1
|
NoSQL Java 数据库
Java分布式锁
Java分布式锁
293 0
|
缓存 Java 数据库
JAVA分布式CAP原则
JAVA分布式CAP原则
399 0
|
缓存 NoSQL Java
大数据-50 Redis 分布式锁 乐观锁 Watch SETNX Lua Redisson分布式锁 Java实现分布式锁
大数据-50 Redis 分布式锁 乐观锁 Watch SETNX Lua Redisson分布式锁 Java实现分布式锁
337 3
大数据-50 Redis 分布式锁 乐观锁 Watch SETNX Lua Redisson分布式锁 Java实现分布式锁
|
分布式计算 NoSQL Java
Hadoop-32 ZooKeeper 分布式锁问题 分布式锁Java实现 附带案例和实现思路代码
Hadoop-32 ZooKeeper 分布式锁问题 分布式锁Java实现 附带案例和实现思路代码
287 2