@getlarge/nestjs-tools-lock
v1.1.0
Published
A distributed lock manager for NestJS
Downloads
125
Maintainers
Readme
Lock
The Lock Service produce distributed locks to prevent duplicated/conflicted actions to be executed in a distributed environment. It is based on Redlock module.
Installation
$ npm install --save @getlarge/nestjs-tools-lock
Usage
Inside a CronJob service
import { LockService } from '@getlarge/nestjs-tools-lock';
import { Injectable } from '@nestjs/common';
import { Cron } from '@nestjs/schedule';
@Injectable()
export class TasksService implements OnModuleDestroy {
constructor(private lockService: LockService) {}
onModuleDestroy() {
this.lockService.close();
}
// using returned unlock function
@Cron('*/10 * * * * *')
async doThis(): Promise<void> {
const lockKey = 'doThis';
const { unlock } = await this.lockService.lock(lockKey, 2000);
if (typeof unlock !== 'function') {
return;
}
unlock();
}
// using lock id
@Cron('*/10 * * * * *')
async doThat(): Promise<void> {
const lockKey = 'doThat';
await this.lockService.optimist(lockKey, 2000);
const { lockId } = await this.lockService.lock(lockKey, 2000);
this.lockService.unlock(lockKey, lockId);
}
}