Spring整合redisson实现分布式锁

本文详细介绍如何在Spring项目中整合Redisson实现分布式锁,包括所需jar包、配置类及工具类代码,最后通过实战测试验证分布式锁的有效性。

在这里插入图片描述

一.你需要准备

  • spring-4.1.7.RELEASE.jar
  • redisson-all-2.10.5.jar

在整合redisson之前,我们是在你的项目已经整合了redis的基础上进行的,关于spring整合redis,我们这里不再赘述;

二.整合redisson

2.1 Redisson配置类

import org.redisson.Redisson;
import org.redisson.config.Config;

/**
 * @author: Milogenius
 * @create: 2019-08-08 17:05
 * @description: 配置Redisson
 **/
public class RedissonManager {

    private static Config config = new Config();

    /**
     * 声明Redisson对象
     */
    private static Redisson redisson = null;

    static{
        config.useSingleServer().setAddress("redis://" + "127.0.0.1" + ":" + "6379").setPassword("milo");
        redisson = (Redisson)Redisson.create(config);
    }

    /**
     * 获取redisson对象的方法
     * @return
     */
    public static Redisson getRedisson(){
        return redisson;
    }
}

2.2 Redisson分布式锁工具类

import com.xwtech.olcs.base.redisson.RedissonManager;
import org.redisson.Redisson;
import org.redisson.api.RLock;

import java.util.concurrent.TimeUnit;

/**
 * @author: Milogenius
 * @create: 2019-08-08 17:06
 * @description: Redisson分布式锁
 **/
public class DistributedRedisLock {


    /**
     * 从配置类中获取redisson对象
     */
    private static Redisson redisson = RedissonManager.getRedisson();

     /**
     * 锁名称前缀[一般建议:锁名称前缀+service名称+方法名称,目的是为了防止重复]
     */
    private static final String LOCK_TITLE = "redisLock_";

    /**
     * 加锁
     * @param lockName 锁名称
     * @return
     */
    public static boolean acquire(String lockName){
        //声明key对象
        String key = LOCK_TITLE + lockName;
        //获取锁对象
        RLock mylock = redisson.getLock(key);
        //加锁,并且设置锁过期时间,防止死锁的产生
        mylock.lock(2, TimeUnit.MINUTES);
        System.err.println("======lock======"+ Thread.currentThread().getName());
        //加锁成功
        return  true;
    }

    /**
     * 锁释放
     * @param lockName 锁名称
     */
    public static void release(String lockName){
        //必须是和加锁时的同一个key
        String key = LOCK_TITLE + lockName;
        //获取所对象
        RLock mylock = redisson.getLock(key);
        //释放锁(解锁)
        mylock.unlock();
        System.err.println("======unlock======"+ Thread.currentThread().getName());
    }
}

三.实战操作

3.1测试类

在测试类中,我们让线程休眠10s,模拟处理业务逻辑,我们在浏览器打开三个窗口,分别请求当前地址;

@Controller
@RequestMapping("test")
public class RedissonTest {

    /**
     * 日志
     */
    private static final Logger logger = LoggerFactory.getLogger(RedissonTest.class);


    @RequestMapping("redisson.do")
    @ResponseBody
    public String redissonTest(){
        String key = "test123";
        //加锁
        DistributedRedisLock.acquire(key);
        logger.info("进入方法");
        try {
            logger.info("当前线程名称:"+Thread.currentThread().getName());
            //do something[等待10s]
            Thread.sleep(10000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        logger.info("方法结束");
        //释放锁
        DistributedRedisLock.release(key);
        return "success";
    }
}

3.2测试结果

通过日志可以发现,三次请求依次执行

说明:由于环境限制,我们本地无法测试分布式环境下的场景,需要大家自测;

在这里插入图片描述

内容概要:本研究聚焦于绿电直连型电氢氨园区的优化运行,提出一种集成绿色电力直接供给、电解水制氢及氢气合成氨工艺的综合能源系统架构。通过建立包含风光发电、电解槽、氨合成反应器、储氢罐、电网交互及多类型负荷在内的系统模型,综合考虑绿电直供优先、能量梯级利用与多能互补原则,构建以系统综合运行成本最小化为目标的优化调度模型。研究采用Matlab与Python工具进行算法求解和仿真分析,利用实际气象与负荷数据完成案例验证,评估了不同运行策略下系统的经济性、可再生能源消纳能力与碳减排效益,为新型电氢氨一体化园区的规划与运行提供了理论依据和技术支撑。; 适合人群:具备一定电力系统、新能源或化工背景的研究生、科研人员及从事综合能源系统规划与优化工作的工程技术人员。; 使用场景及目标:①用于科研学习,理解电-氢-氨多能转换系统的建模与优化方法;②为工业园区的低碳化、智能化改造提供技术参考与决策支持;③作为开发类似综合能源管理系统的理论基础。; 阅读建议:此资源包含完整的模型代码、数据与论文,使用者应结合代码仔细研读论文中的模型构建部分,重点关注目标函数与约束条件的设计逻辑,并尝试修改参数进行仿真,以深入掌握优化算法在实际系统中的应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值