redission分布式锁java代码
时间: 2024-05-14 11:10:49 浏览: 177
Redisson是一个基于Redis实现的Java分布式对象服务框架,提供了许多分布式应用中常用的对象和服务。其中就包括分布式锁。下面是使用Redisson实现分布式锁的Java代码示例:
```
// 初始化Redisson客户端
Config config = new Config();
config.useSingleServer().setAddress("redis://127.0.0.1:6379");
RedissonClient redissonClient = Redisson.create(config);
// 获取分布式锁对象
RLock lock = redissonClient.getLock("myLock");
try {
// 尝试获取锁并执行业务代码
lock.lock();
// 执行业务代码
} finally {
// 释放锁
lock.unlock();
}
// 关闭Redisson客户端
redissonClient.shutdown();
```
在上面的代码中,我们首先使用Redisson的`Config`对象初始化了一个Redisson客户端,然后通过客户端对象获取了一个分布式锁对象`RLock`。在`try`块中,我们尝试获取锁并执行业务代码,使用完毕后再通过`finally`块释放锁。最后,我们通过`shutdown()`方法关闭Redisson客户端。
相关问题
java封装Redission分布式锁
Redisson 是一个基于 Redis 的 Java 驻内存数据网格(In-Memory Data Grid)。它提供了一些分布式锁的实现,包括可重入锁、公平锁、联锁等。下面是使用 Redisson 实现分布式锁的示例代码:
1. 引入 Redisson 依赖
```xml
<dependency>
<groupId>org.redisson</groupId>
<artifactId>redisson</artifactId>
<version>3.12.5</version>
</dependency>
```
2. 创建 Redisson 客户端
```java
Config config = new Config();
config.useSingleServer().setAddress("redis://127.0.0.1:6379");
RedissonClient redisson = Redisson.create(config);
```
3. 获取锁
```java
RLock lock = redisson.getLock("mylock");
lock.lock();
try {
// 执行业务逻辑
} finally {
lock.unlock();
}
```
在获取锁时,如果锁已经被其他线程占用,则当前线程会阻塞等待锁的释放。可以通过 `lock.tryLock()` 方法尝试获取锁而不阻塞等待。
```java
RLock lock = redisson.getLock("mylock");
if (lock.tryLock()) {
try {
// 执行业务逻辑
} finally {
lock.unlock();
}
} else {
// 获取锁失败
}
```
4. 关闭 Redisson 客户端
```java
redisson.shutdown();
```
封装后的分布式锁示例:
```java
import org.redisson.Redisson;
import org.redisson.api.RLock;
import org.redisson.api.RedissonClient;
import org.redisson.config.Config;
public class DistributedLock {
private static RedissonClient redisson;
static {
Config config = new Config();
config.useSingleServer().setAddress("redis://127.0.0.1:6379");
redisson = Redisson.create(config);
}
public static RLock getLock(String lockKey) {
return redisson.getLock(lockKey);
}
public static void shutdown() {
redisson.shutdown();
}
}
```
使用示例:
```java
RLock lock = DistributedLock.getLock("mylock");
lock.lock();
try {
// 执行业务逻辑
} finally {
lock.unlock();
}
DistributedLock.shutdown();
```
java8 和redission分布式锁写法
Java8 和 Redisson 都提供了方便易用的分布式锁实现,下面分别介绍它们的写法。
Java8 实现分布式锁
Java8 提供了 `java.util.concurrent.locks.StampedLock` 类来实现乐观读写锁,可以用它来实现分布式锁。但是需要注意的是,StampedLock 并不是一个分布式锁,它只能实现本地线程之间的锁控制,需要结合其他技术来实现分布式锁。
下面是一个基于 Java8 和 Redis 的分布式锁实现示例代码:
```java
import java.util.concurrent.TimeUnit;
import java.util.concurrent.locks.LockSupport;
import java.util.function.Supplier;
import org.redisson.api.RLock;
import org.redisson.api.RedissonClient;
public class DistributedLock {
private RedissonClient redissonClient;
public DistributedLock(RedissonClient redissonClient) {
this.redissonClient = redissonClient;
}
public <T> T lock(String lockKey, Supplier<T> supplier) {
RLock lock = redissonClient.getLock(lockKey);
lock.lock();
try {
return supplier.get();
} finally {
lock.unlock();
}
}
public <T> T tryLock(String lockKey, Supplier<T> supplier, long timeout, TimeUnit unit) {
RLock lock = redissonClient.getLock(lockKey);
boolean locked = false;
try {
locked = lock.tryLock(timeout, unit);
if (locked) {
return supplier.get();
} else {
return null;
}
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
return null;
} finally {
if (locked) {
lock.unlock();
}
}
}
public void park(long timeout, TimeUnit unit) {
LockSupport.parkNanos(unit.toNanos(timeout));
}
}
```
上述示例代码中,`lock` 方法是阻塞获取锁的方法,如果获取锁失败,线程会一直阻塞,直到获取到锁。`tryLock` 方法是非阻塞获取锁的方法,如果获取锁失败,会返回 null。`park` 方法是挂起当前线程的方法。
Redisson 实现分布式锁
Redisson 是一个开源的 Java Redis 客户端,提供了丰富的 Redis 分布式相关功能,包括分布式锁。下面是一个基于 Redisson 的分布式锁实现示例代码:
```java
import java.util.concurrent.TimeUnit;
import java.util.function.Supplier;
import org.redisson.api.RLock;
import org.redisson.api.RedissonClient;
public class DistributedLock {
private RedissonClient redissonClient;
public DistributedLock(RedissonClient redissonClient) {
this.redissonClient = redissonClient;
}
public <T> T lock(String lockKey, Supplier<T> supplier) {
RLock lock = redissonClient.getLock(lockKey);
lock.lock();
try {
return supplier.get();
} finally {
lock.unlock();
}
}
public <T> T tryLock(String lockKey, Supplier<T> supplier, long timeout, TimeUnit unit) {
RLock lock = redissonClient.getLock(lockKey);
boolean locked = false;
try {
locked = lock.tryLock(timeout, unit);
if (locked) {
return supplier.get();
} else {
return null;
}
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
return null;
} finally {
if (locked) {
lock.unlock();
}
}
}
public void park(long timeout, TimeUnit unit) {
LockSupport.parkNanos(unit.toNanos(timeout));
}
}
```
上述示例代码中,`lock` 方法和 `tryLock` 方法都是通过 Redisson 提供的 `RLock` 接口来实现的。其中,`lock` 方法是阻塞获取锁的方法,如果获取锁失败,线程会一直阻塞,直到获取到锁。`tryLock` 方法是非阻塞获取锁的方法,如果获取锁失败,会返回 null。`park` 方法是挂起当前线程的方法。
阅读全文