nicelock:一个注解,即可使用Java的锁;支持本地锁和分布式锁(分布式锁基于Redisson,稳定!)。
<dependency>
<groupId>com.suchtool</groupId>
<artifactId>nicelock-spring-boot-starter</artifactId>
<version>{newest-version}</version>
</dependency>
本组件默认使用本地缓存。
如果要使用redis,需要引入redisson-spring-boot-starter依赖,并配置。
引入依赖:
<dependency>
<groupId>org.redisson</groupId>
<artifactId>redisson-spring-boot-starter</artifactId>
<version>3.16.6</version>
</dependency>
添加Redisson相关配置,比如:
spring:
redis:
host: 127.0.0.1
port: 6379
password: 222333
@NiceLock(keys = {"#user.id", "#orderNo"})
public String editOrder(User user, String orderNo) {
System.out.println("修改订单");
return "success";
}
默认情况下,本组件在@Transactional之前执行。你可以指定本组件的执行顺序,在SpringBoot的启动类上加如下注解即可:
@EnableNiceLock(order = 1)
比如:
package com.knife.example;
import com.suchtool.nicelock.annotation.EnableNiceLock;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
@EnableNiceLock(order = 1)
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
}
支持yml等配置方式。
配置 | 描述 | 默认值 |
---|---|---|
suchtool.nicelock.storage-type | 存储方式。可选值:local、redis | local(本地) |
suchtool.nicelock.key-prefix | 缓存的key的前缀 | nicelock |