Redis-based distributed lock module for NestJS, built on @redis-kit/lock
npm install @nestjs-redis/lock
Distributed locking for NestJS using Redis and the Redlock algorithm




 
---
- Redlock-based distributed locks
- Works with existing @nestjs-redis/client connections
- Decorator @Redlock() and RedlockService
- Type-safe, production-ready
``bash`
npm install @nestjs-redis/lock @nestjs-redis/client redis
The recommended approach is to use RedisModule from @nestjs-redis/client so Redis connections are lifecycle-managed by Nest (connect/disconnect with your app). Alternatively, you can pass your own Redis client (e.g. created with createClient() from redis) and manage its lifecycle yourself.
`typescript
// app.module.ts
import { Module } from '@nestjs/common';
import { RedisModule, RedisToken } from '@nestjs-redis/client';
import { RedlockModule } from '@nestjs-redis/lock';
@Module({
imports: [
RedisModule.forRoot({ options: { url: 'redis://localhost:6379' } }),
RedlockModule.forRootAsync({
inject: [RedisToken()],
useFactory: (redis) => ({ clients: [redis] }),
}),
],
})
export class AppModule {}
`
`typescript
import { Injectable } from '@nestjs/common';
import { Redlock } from '@nestjs-redis/lock';
@Injectable()
export class UserService {
@Redlock('user:update', 5000)
async updateUserBalance(userId: string, amount: number) {
// critical work
}
}
`
`typescript
@Injectable()
export class PaymentService {
constructor(private readonly redlock: RedlockService) {}
async processPayment(paymentId: string) {
return this.redlock.withLock([payment:${paymentId}], 5000, async () => {``
// critical work
});
}
}
- Root repo: CSenshi/nestjs-redis
- Issues: GitHub Issues
- Discussions: GitHub Discussions
- Built on @redis-kit/lock: docs
Please see the root contributing guidelines.
MIT © CSenshi