SpringBoot集成Lock4j 底层使用Redission 实现分布锁

Lock4j

在这里插入图片描述

在分布式系统中,实现锁的功能对于保证数据一致性和避免并发冲突是非常重要的。Lock4j是一个简单易用的分布式锁框架,而Redisson是一个功能强大的分布式解决方案,可以与Lock4j进行集成。

操作步骤

第一步:添加依赖

首先,在你的Spring Boot项目的pom.xml文件中添加以下依赖:

<dependencies>
    <!--若使用redisTemplate作为分布式锁底层,则需要引入-->
    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>lock4j-redis-template-spring-boot-starter</artifactId>
        <version>${latest.version}</version>
    </dependency>
    <!--若使用redisson作为分布式锁底层,则需要引入-->
    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>lock4j-redisson-spring-boot-starter</artifactId>
        <version>${latest.version}</version>
    </dependency>
    <!--若使用zookeeper作为分布式锁底层,则需要引入-->
    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>lock4j-zookeeper-spring-boot-starter</artifactId>
        <version>${latest.version}</version>
    </dependency>
</dependencies>

这些依赖将会引入Redisson和Lock4j以及它们的必要依赖。

第二步:配置Redis

在src/main/resources目录下创建application.yml文件,并添加以下配置:

spring:
  redis:
    host: 127.0.0.1
    port: 6379
    password: ddz123
    database: 0

这是一个示例配置文件,你需要根据自己的实际情况修改Redis的连接信息,如地址、端口、密码等。

第三步:使用@Lock4j注解实现分布式锁

在你的Spring Boot应用程序中,创建一个测试类,用于ApiPost的调用两次第一个会获取到锁,第二个获取锁失败会抛出异常。

    @GetMapping("/lock")
    @Lock4j(keys = {"#id"}, acquireTimeout = 100, expire = 10000
//            , executor = RedissonLockExecutor.class
    )
    public String getLock(String id) throws InterruptedException {
        Thread.sleep(10000);
        return id;
    }

在这里插入图片描述

自定义锁

自定义锁key的生成规则

只需要实现LockKeyBuilder接口中 buildKey() 方法即可定义自己的生成规则。

@Component
public class CustomKeyBuilder implements LockKeyBuilder {
    /**
     * 构建key
     *
     * @param invocation     invocation
     * @param definitionKeys 定义
     * @return key
     */
    @Override
    public String buildKey(MethodInvocation invocation, String[] definitionKeys) {
        // 自定义锁key的生成策略
        return null;
    }
}

自定义锁失败策略

实现LockFailureStrategy接口中onLockFailure() 方法即可自定义获取锁失败返回策略。

@Component
public class GrabLockFailureStrategy implements LockFailureStrategy {
    /**
     * 锁失败事件
     *
     * @param key       锁key
     * @param method    方法
     * @param arguments 自变量
     */
    @Override
    public void onLockFailure(String key, Method method, Object[] arguments) {
        throw new RuntimeException("获取锁失败了!");
    }
}

自定义加锁解锁逻辑

@Component
public class RedissonLockExecutor extends AbstractLockExecutor<RLock> {
    /**
     * 加锁
     *
     * @param lockKey        锁标识
     * @param lockValue      锁值
     * @param expire         锁有效时间
     * @param acquireTimeout 获取锁超时时间
     * @return 锁信息
     */
    @Override
    public RLock acquire(String lockKey, String lockValue, long expire, long acquireTimeout) {
        return null;
    }

    /**
     * 解锁
     *
     * <pre>
     * 为何解锁需要校验lockValue
     * 客户端A加锁,一段时间之后客户端A解锁,在执行releaseLock之前,锁突然过期了。
     * 此时客户端B尝试加锁成功,然后客户端A再执行releaseLock方法,则将客户端B的锁给解除了。
     * </pre>
     *
     * @param key          加锁key
     * @param value        加锁value
     * @param lockInstance 锁实例
     * @return 是否释放成功
     */
    @Override
    public boolean releaseLock(String key, String value, RLock lockInstance) {
        return false;
    }
}

注意事项

在使用Spring Boot集成Lock4j和Redisson时,需要注意以下事项:

  • 确保Redisson的配置正确。在redisson.yaml文件(或application.properties)中,你需要提供正确的Redis连接信息,如地址、端口、密码等。确保你的Redis服务运行正常。
  • 注意锁的名称要保证唯一性。不同的锁需要使用不同的锁名称。使用相同名称的锁可能会导致不同方法之间的锁冲突。
  • 考虑对方法异常进行处理。为了确保锁能够被正确释放,你可以在方法中使用try-catch-finally结构,并在finally块中释放锁。这样即使方法出现异常,也能保证锁的守护不会因异常而中断。

通过以上步骤和注意事项,你可以轻松地在Spring Boot项目中集成Lock4j,并使用Redisson作为底层实现分布式锁。这样,你可以安全地处理分布式系统中的并发问题,并保证数据的一致性。

好的,我可以为您提供有关于SpringBoot整合Redisson实现分布的相关信息。 首先,您需要在您的SpringBoot项目中添加Redisson的依赖,可以在pom.xml文件中添加如下依赖: ```xml <dependency> <groupId>org.redisson</groupId> <artifactId>redisson-spring-boot-starter</artifactId> <version>${redisson.version}</version> </dependency> ``` 其中,`${redisson.version}`为Redisson的版本号。 接下来,在您的项目中创建一个RedissonConfig类,用于配置Redisson连接池和RedissonClient对象的实例化。示例代码如下: ```java @Configuration public class RedissonConfig { @Autowired private RedisProperties redisProperties; @Bean public RedissonClient redissonClient() { Config config = new Config(); String address = "redis://" + redisProperties.getHost() + ":" + redisProperties.getPort(); config.useSingleServer().setAddress(address).setDatabase(redisProperties.getDatabase()) .setPassword(redisProperties.getPassword()); return Redisson.create(config); } } ``` 在上述示例代码中,我们通过读取Redis的连接配置信息,使用单节点连接Redis。您也可以根据您的实际需要进行配置。 接下来,我们可以通过RedissonClient对象来获取分布。示例代码如下: ```java @Autowired private RedissonClient redissonClient; public void acquireLock() { RLock lock = redissonClient.getLock("myLock"); lock.lock(); try { // 这里是您的业务逻辑代码 } finally { lock.unlock(); } } ``` 在上述示例代码中,我们首先通过`redissonClient.getLock("myLock")`获取一个名为"myLock"的分布。然后,我们调用`lock.lock()`方法来获取,如果获取失败则会一直阻塞直到获取成功。在业务逻辑执行完成后,我们通过`lock.unlock()`方法来释放。 以上就是使用Redisson实现分布的整合方式。希望对您有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

LOVE_DDZ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值