Skip to content

一个注解,即可使用Java的分布式锁。(基于Redisson)

License

Notifications You must be signed in to change notification settings

knife-blade/nicelock

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

nicelock

1.介绍

nicelock:一个注解,即可使用Java的锁;支持本地锁和分布式锁(分布式锁基于Redisson,稳定!)。

2.快速使用

1.引入依赖

<dependency>
    <groupId>com.suchtool</groupId>
    <artifactId>nicelock-spring-boot-starter</artifactId>
    <version>{newest-version}</version>
</dependency>

2.配置缓存方式

本组件默认使用本地缓存。

如果要使用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

3.使用

@NiceLock(keys = {"#user.id", "#orderNo"})
public String editOrder(User user, String orderNo) {
    System.out.println("修改订单");
    return "success";
}

3.详细配置

1.执行顺序

默认情况下,本组件在@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);
    }

}

2.配置大全

支持yml等配置方式。

配置 描述 默认值
suchtool.nicelock.storage-type 存储方式。可选值:local、redis local(本地)
suchtool.nicelock.key-prefix 缓存的key的前缀 nicelock

About

一个注解,即可使用Java的分布式锁。(基于Redisson)

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages