redis-semaphore
Version:
Distributed mutex and semaphore based on Redis
21 lines (17 loc) • 532 B
text/typescript
import createDebug from 'debug'
import Redis from 'ioredis'
import { releaseLua } from '../multiSemaphore/release/lua'
const debug = createDebug('redis-semaphore:redlock-mutex:release')
export async function releaseRedlockMultiSemaphore(
clients: Redis[],
key: string,
permits: number,
identifier: string
) {
debug(key, identifier)
const promises = clients.map(client =>
releaseLua(client, [key, permits, identifier]).catch(() => 0)
)
const results = await Promise.all(promises)
debug('results', results)
}