@platformatic/job-queue 0.1.0 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +57 -4
- package/dist/consumer.d.ts +5 -2
- package/dist/consumer.d.ts.map +1 -1
- package/dist/consumer.js +127 -31
- package/dist/consumer.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/producer.d.ts +8 -2
- package/dist/producer.d.ts.map +1 -1
- package/dist/producer.js +64 -3
- package/dist/producer.js.map +1 -1
- package/dist/queue.d.ts +5 -1
- package/dist/queue.d.ts.map +1 -1
- package/dist/queue.js +59 -12
- package/dist/queue.js.map +1 -1
- package/dist/reaper.d.ts +3 -1
- package/dist/reaper.d.ts.map +1 -1
- package/dist/reaper.js +21 -10
- package/dist/reaper.js.map +1 -1
- package/dist/storage/file.d.ts +5 -2
- package/dist/storage/file.d.ts.map +1 -1
- package/dist/storage/file.js +172 -49
- package/dist/storage/file.js.map +1 -1
- package/dist/storage/memory.d.ts +2 -2
- package/dist/storage/memory.d.ts.map +1 -1
- package/dist/storage/memory.js +5 -5
- package/dist/storage/memory.js.map +1 -1
- package/dist/storage/redis.d.ts +4 -2
- package/dist/storage/redis.d.ts.map +1 -1
- package/dist/storage/redis.js +67 -21
- package/dist/storage/redis.js.map +1 -1
- package/dist/storage/types.d.ts +2 -2
- package/dist/storage/types.d.ts.map +1 -1
- package/dist/storage/utils.d.ts +2 -0
- package/dist/storage/utils.d.ts.map +1 -0
- package/dist/storage/utils.js +31 -0
- package/dist/storage/utils.js.map +1 -0
- package/dist/types.d.ts +41 -0
- package/dist/types.d.ts.map +1 -1
- package/dist/utils/id.d.ts.map +1 -1
- package/dist/utils/id.js +1 -4
- package/dist/utils/id.js.map +1 -1
- package/dist/utils/logging.d.ts +5 -0
- package/dist/utils/logging.d.ts.map +1 -0
- package/dist/utils/logging.js +24 -0
- package/dist/utils/logging.js.map +1 -0
- package/package.json +7 -2
package/dist/producer.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { JobFailedError, TimeoutError } from "./errors.js";
|
|
2
2
|
import { createJsonSerde } from "./serde/index.js";
|
|
3
|
+
import { abstractLogger } from "./utils/logging.js";
|
|
3
4
|
import { parseState } from "./utils/state.js";
|
|
4
5
|
/**
|
|
5
6
|
* Producer handles enqueueing jobs and retrieving results
|
|
@@ -10,12 +11,14 @@ export class Producer {
|
|
|
10
11
|
#resultSerde;
|
|
11
12
|
#maxRetries;
|
|
12
13
|
#resultTTL;
|
|
14
|
+
#logger;
|
|
13
15
|
constructor(config) {
|
|
14
16
|
this.#storage = config.storage;
|
|
15
17
|
this.#payloadSerde = config.payloadSerde ?? createJsonSerde();
|
|
16
18
|
this.#resultSerde = config.resultSerde ?? createJsonSerde();
|
|
17
19
|
this.#maxRetries = config.maxRetries ?? 3;
|
|
18
20
|
this.#resultTTL = config.resultTTL ?? 3600000; // 1 hour
|
|
21
|
+
this.#logger = (config.logger ?? abstractLogger).child({ component: 'producer' });
|
|
19
22
|
}
|
|
20
23
|
/**
|
|
21
24
|
* Enqueue a job (fire-and-forget)
|
|
@@ -23,25 +26,32 @@ export class Producer {
|
|
|
23
26
|
async enqueue(id, payload, options) {
|
|
24
27
|
const timestamp = Date.now();
|
|
25
28
|
const maxAttempts = options?.maxAttempts ?? this.#maxRetries;
|
|
29
|
+
const resultTTL = options?.resultTTL ?? this.#resultTTL;
|
|
30
|
+
this.#logger.trace({ id, maxAttempts, resultTTL }, 'Enqueue requested.');
|
|
31
|
+
this.#validateResultTTL(resultTTL);
|
|
26
32
|
const message = {
|
|
27
33
|
id,
|
|
28
34
|
payload,
|
|
29
35
|
createdAt: timestamp,
|
|
30
36
|
attempts: 0,
|
|
31
|
-
maxAttempts
|
|
37
|
+
maxAttempts,
|
|
38
|
+
resultTTL
|
|
32
39
|
};
|
|
33
40
|
const serialized = this.#payloadSerde.serialize(message);
|
|
34
41
|
const existingState = await this.#storage.enqueue(id, serialized, timestamp);
|
|
35
42
|
if (existingState) {
|
|
36
43
|
const { status } = parseState(existingState);
|
|
44
|
+
this.#logger.debug({ id, status }, 'Duplicate enqueue detected.');
|
|
37
45
|
if (status === 'completed') {
|
|
38
46
|
const result = await this.getResult(id);
|
|
39
47
|
if (result !== null) {
|
|
48
|
+
this.#logger.debug({ id }, 'Returning cached completed result.');
|
|
40
49
|
return { status: 'completed', result };
|
|
41
50
|
}
|
|
42
51
|
}
|
|
43
52
|
return { status: 'duplicate', existingState: status };
|
|
44
53
|
}
|
|
54
|
+
this.#logger.debug({ id }, 'Job enqueued.');
|
|
45
55
|
return { status: 'queued' };
|
|
46
56
|
}
|
|
47
57
|
/**
|
|
@@ -49,9 +59,11 @@ export class Producer {
|
|
|
49
59
|
*/
|
|
50
60
|
async enqueueAndWait(id, payload, options) {
|
|
51
61
|
const timeout = options?.timeout ?? 30000;
|
|
62
|
+
this.#logger.trace({ id, timeout }, 'EnqueueAndWait requested.');
|
|
52
63
|
// Subscribe BEFORE enqueue to avoid race conditions
|
|
53
64
|
const { promise: resultPromise, resolve: resolveResult, reject: rejectResult } = Promise.withResolvers();
|
|
54
65
|
const unsubscribe = await this.#storage.subscribeToJob(id, async (status) => {
|
|
66
|
+
this.#logger.trace({ id, status }, 'Received job notification.');
|
|
55
67
|
if (status === 'completed') {
|
|
56
68
|
const result = await this.getResult(id);
|
|
57
69
|
if (result !== null) {
|
|
@@ -70,20 +82,25 @@ export class Producer {
|
|
|
70
82
|
const enqueueResult = await this.enqueue(id, payload, options);
|
|
71
83
|
// If already completed, return cached result immediately
|
|
72
84
|
if (enqueueResult.status === 'completed') {
|
|
85
|
+
this.#logger.debug({ id }, 'EnqueueAndWait resolved from cached result.');
|
|
73
86
|
return enqueueResult.result;
|
|
74
87
|
}
|
|
75
88
|
// If duplicate and already failed, throw immediately
|
|
76
89
|
if (enqueueResult.status === 'duplicate' && enqueueResult.existingState === 'failed') {
|
|
77
90
|
const error = await this.#storage.getError(id);
|
|
78
91
|
const errorMessage = error ? error.toString() : 'Job failed';
|
|
92
|
+
this.#logger.warn({ id }, 'EnqueueAndWait found already failed duplicate job.');
|
|
79
93
|
throw new JobFailedError(id, errorMessage);
|
|
80
94
|
}
|
|
81
95
|
// Wait for result with timeout
|
|
82
96
|
const { promise: timeoutPromise, reject: rejectTimeout } = Promise.withResolvers();
|
|
83
97
|
timeoutId = setTimeout(() => {
|
|
98
|
+
this.#logger.warn({ id, timeout }, 'EnqueueAndWait timed out.');
|
|
84
99
|
rejectTimeout(new TimeoutError(id, timeout));
|
|
85
100
|
}, timeout);
|
|
86
|
-
|
|
101
|
+
const result = await Promise.race([resultPromise, timeoutPromise]);
|
|
102
|
+
this.#logger.debug({ id }, 'EnqueueAndWait resolved.');
|
|
103
|
+
return result;
|
|
87
104
|
}
|
|
88
105
|
finally {
|
|
89
106
|
if (timeoutId !== undefined) {
|
|
@@ -96,8 +113,10 @@ export class Producer {
|
|
|
96
113
|
* Cancel a pending job
|
|
97
114
|
*/
|
|
98
115
|
async cancel(id) {
|
|
116
|
+
this.#logger.trace({ id }, 'Cancel requested.');
|
|
99
117
|
const state = await this.#storage.getJobState(id);
|
|
100
118
|
if (!state) {
|
|
119
|
+
this.#logger.trace({ id }, 'Cancel target not found.');
|
|
101
120
|
return { status: 'not_found' };
|
|
102
121
|
}
|
|
103
122
|
const { status } = parseState(state);
|
|
@@ -110,6 +129,7 @@ export class Producer {
|
|
|
110
129
|
// Can cancel if queued or failing
|
|
111
130
|
const deleted = await this.#storage.deleteJob(id);
|
|
112
131
|
if (deleted) {
|
|
132
|
+
this.#logger.debug({ id }, 'Job cancelled.');
|
|
113
133
|
return { status: 'cancelled' };
|
|
114
134
|
}
|
|
115
135
|
return { status: 'not_found' };
|
|
@@ -122,8 +142,43 @@ export class Producer {
|
|
|
122
142
|
if (!resultBuffer) {
|
|
123
143
|
return null;
|
|
124
144
|
}
|
|
145
|
+
this.#logger.trace({ id }, 'Deserializing job result.');
|
|
125
146
|
return this.#resultSerde.deserialize(resultBuffer);
|
|
126
147
|
}
|
|
148
|
+
/**
|
|
149
|
+
* Update TTL for a terminal job payload (result for completed jobs, error for failed jobs).
|
|
150
|
+
*/
|
|
151
|
+
async updateResultTTL(id, ttlMs) {
|
|
152
|
+
this.#logger.trace({ id, ttlMs }, 'UpdateResultTTL requested.');
|
|
153
|
+
this.#validateResultTTL(ttlMs);
|
|
154
|
+
const state = await this.#storage.getJobState(id);
|
|
155
|
+
if (!state) {
|
|
156
|
+
return { status: 'not_found' };
|
|
157
|
+
}
|
|
158
|
+
const { status } = parseState(state);
|
|
159
|
+
if (status !== 'completed' && status !== 'failed') {
|
|
160
|
+
this.#logger.debug({ id, status }, 'UpdateResultTTL rejected for non-terminal job.');
|
|
161
|
+
return { status: 'not_terminal' };
|
|
162
|
+
}
|
|
163
|
+
if (status === 'completed') {
|
|
164
|
+
const existingResult = await this.#storage.getResult(id);
|
|
165
|
+
if (!existingResult) {
|
|
166
|
+
this.#logger.warn({ id }, 'UpdateResultTTL missing completed payload.');
|
|
167
|
+
return { status: 'missing_payload' };
|
|
168
|
+
}
|
|
169
|
+
await this.#storage.setResult(id, existingResult, ttlMs);
|
|
170
|
+
this.#logger.debug({ id, ttlMs }, 'Updated completed payload TTL.');
|
|
171
|
+
return { status: 'updated' };
|
|
172
|
+
}
|
|
173
|
+
const existingError = await this.#storage.getError(id);
|
|
174
|
+
if (!existingError) {
|
|
175
|
+
this.#logger.warn({ id }, 'UpdateResultTTL missing failed payload.');
|
|
176
|
+
return { status: 'missing_payload' };
|
|
177
|
+
}
|
|
178
|
+
await this.#storage.setError(id, existingError, ttlMs);
|
|
179
|
+
this.#logger.debug({ id, ttlMs }, 'Updated failed payload TTL.');
|
|
180
|
+
return { status: 'updated' };
|
|
181
|
+
}
|
|
127
182
|
/**
|
|
128
183
|
* Get the status of a job
|
|
129
184
|
*/
|
|
@@ -159,5 +214,11 @@ export class Producer {
|
|
|
159
214
|
}
|
|
160
215
|
return messageStatus;
|
|
161
216
|
}
|
|
217
|
+
#validateResultTTL(resultTTL) {
|
|
218
|
+
if (!Number.isFinite(resultTTL) || !Number.isInteger(resultTTL) || resultTTL <= 0) {
|
|
219
|
+
this.#logger.error({ resultTTL }, 'Invalid resultTTL provided.');
|
|
220
|
+
throw new TypeError('resultTTL must be a positive integer in milliseconds');
|
|
221
|
+
}
|
|
222
|
+
}
|
|
162
223
|
}
|
|
163
224
|
//# sourceMappingURL=producer.js.map
|
package/dist/producer.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"producer.js","sourceRoot":"","sources":["../src/producer.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"producer.js","sourceRoot":"","sources":["../src/producer.ts"],"names":[],"mappings":"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"}
|
package/dist/queue.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { EventEmitter } from 'node:events';
|
|
2
|
-
import type {
|
|
2
|
+
import type { CancelResult, EnqueueAndWaitOptions, EnqueueOptions, EnqueueResult, JobHandler, MessageStatus, QueueConfig, QueueEvents, UpdateResultTTLResult } from './types.ts';
|
|
3
3
|
/**
|
|
4
4
|
* Queue class combining Producer and Consumer functionality
|
|
5
5
|
*/
|
|
@@ -34,6 +34,10 @@ export declare class Queue<TPayload, TResult = void> extends EventEmitter<QueueE
|
|
|
34
34
|
* Get the result of a completed job
|
|
35
35
|
*/
|
|
36
36
|
getResult(id: string): Promise<TResult | null>;
|
|
37
|
+
/**
|
|
38
|
+
* Update TTL for a terminal job payload (result or error).
|
|
39
|
+
*/
|
|
40
|
+
updateResultTTL(id: string, ttlMs: number): Promise<UpdateResultTTLResult>;
|
|
37
41
|
/**
|
|
38
42
|
* Get the status of a job
|
|
39
43
|
*/
|
package/dist/queue.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"queue.d.ts","sourceRoot":"","sources":["../src/queue.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"queue.d.ts","sourceRoot":"","sources":["../src/queue.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAO1C,OAAO,KAAK,EAEV,YAAY,EACZ,qBAAqB,EACrB,cAAc,EACd,aAAa,EACb,UAAU,EACV,aAAa,EACb,WAAW,EACX,WAAW,EACX,qBAAqB,EACtB,MAAM,YAAY,CAAA;AAGnB;;GAEG;AACH,qBAAa,KAAK,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI,CAAE,SAAQ,YAAY,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;;gBAkBxE,MAAM,EAAE,WAAW,CAAC,QAAQ,EAAE,OAAO,CAAC;IAyBnD;;OAEG;IACG,KAAK,IAAK,OAAO,CAAC,IAAI,CAAC;IAmB7B;;OAEG;IACG,IAAI,IAAK,OAAO,CAAC,IAAI,CAAC;IAoB5B;;OAEG;IACH,OAAO,CAAE,OAAO,EAAE,UAAU,CAAC,QAAQ,EAAE,OAAO,CAAC,GAAG,IAAI;IAUtD;;OAEG;IACG,OAAO,CAAE,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,CAAC,EAAE,cAAc,GAAG,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;IAUxG;;OAEG;IACG,cAAc,CAAE,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,CAAC,EAAE,qBAAqB,GAAG,OAAO,CAAC,OAAO,CAAC;IAOvG;;OAEG;IACG,MAAM,CAAE,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAUhD;;OAEG;IACG,SAAS,CAAE,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;IAIrD;;OAEG;IACG,eAAe,CAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,qBAAqB,CAAC;IAOjF;;OAEG;IACG,SAAS,CAAE,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC;CAgErE"}
|
package/dist/queue.js
CHANGED
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { EventEmitter } from 'node:events';
|
|
2
1
|
import { randomUUID } from 'node:crypto';
|
|
3
|
-
import {
|
|
2
|
+
import { EventEmitter } from 'node:events';
|
|
4
3
|
import { Consumer } from "./consumer.js";
|
|
4
|
+
import { Producer } from "./producer.js";
|
|
5
5
|
import { createJsonSerde } from "./serde/index.js";
|
|
6
|
+
import { abstractLogger, ensureLoggableError } from "./utils/logging.js";
|
|
6
7
|
/**
|
|
7
8
|
* Queue class combining Producer and Consumer functionality
|
|
8
9
|
*/
|
|
@@ -20,6 +21,8 @@ export class Queue extends EventEmitter {
|
|
|
20
21
|
#maxRetries;
|
|
21
22
|
#resultTTL;
|
|
22
23
|
#visibilityTimeout;
|
|
24
|
+
#afterExecution;
|
|
25
|
+
#logger;
|
|
23
26
|
constructor(config) {
|
|
24
27
|
super();
|
|
25
28
|
this.#storage = config.storage;
|
|
@@ -31,39 +34,51 @@ export class Queue extends EventEmitter {
|
|
|
31
34
|
this.#maxRetries = config.maxRetries ?? 3;
|
|
32
35
|
this.#resultTTL = config.resultTTL ?? 3600000;
|
|
33
36
|
this.#visibilityTimeout = config.visibilityTimeout ?? 30000;
|
|
37
|
+
this.#afterExecution = config.afterExecution;
|
|
38
|
+
this.#logger = (config.logger ?? abstractLogger).child({ component: 'queue', workerId: this.#workerId });
|
|
34
39
|
this.#producer = new Producer({
|
|
35
40
|
storage: this.#storage,
|
|
36
41
|
payloadSerde: this.#payloadSerde,
|
|
37
42
|
resultSerde: this.#resultSerde,
|
|
38
43
|
maxRetries: this.#maxRetries,
|
|
39
|
-
resultTTL: this.#resultTTL
|
|
44
|
+
resultTTL: this.#resultTTL,
|
|
45
|
+
logger: this.#logger
|
|
40
46
|
});
|
|
41
47
|
}
|
|
42
48
|
/**
|
|
43
49
|
* Start the queue (connects storage and starts consumer if handler registered)
|
|
44
50
|
*/
|
|
45
51
|
async start() {
|
|
46
|
-
if (this.#started)
|
|
52
|
+
if (this.#started) {
|
|
53
|
+
this.#logger.trace('Queue already started.');
|
|
47
54
|
return;
|
|
55
|
+
}
|
|
56
|
+
this.#logger.debug('Starting queue.');
|
|
48
57
|
await this.#storage.connect();
|
|
49
58
|
this.#started = true;
|
|
50
59
|
// If handler was registered, start consumer
|
|
51
60
|
if (this.#handler) {
|
|
52
61
|
this.#startConsumer();
|
|
53
62
|
}
|
|
63
|
+
this.#logger.debug('Queue started.');
|
|
54
64
|
this.emit('started');
|
|
55
65
|
}
|
|
56
66
|
/**
|
|
57
67
|
* Stop the queue gracefully
|
|
58
68
|
*/
|
|
59
69
|
async stop() {
|
|
60
|
-
if (!this.#started)
|
|
70
|
+
if (!this.#started) {
|
|
71
|
+
this.#logger.trace('Queue already stopped.');
|
|
61
72
|
return;
|
|
73
|
+
}
|
|
74
|
+
this.#logger.debug('Stopping queue.');
|
|
62
75
|
if (this.#consumer) {
|
|
63
76
|
await this.#consumer.stop();
|
|
77
|
+
this.#consumer = null;
|
|
64
78
|
}
|
|
65
79
|
await this.#storage.disconnect();
|
|
66
80
|
this.#started = false;
|
|
81
|
+
this.#logger.debug('Queue stopped.');
|
|
67
82
|
this.emit('stopped');
|
|
68
83
|
}
|
|
69
84
|
/**
|
|
@@ -71,6 +86,7 @@ export class Queue extends EventEmitter {
|
|
|
71
86
|
*/
|
|
72
87
|
execute(handler) {
|
|
73
88
|
this.#handler = handler;
|
|
89
|
+
this.#logger.debug('Registered queue handler.');
|
|
74
90
|
// If already started, create and start consumer
|
|
75
91
|
if (this.#started) {
|
|
76
92
|
this.#startConsumer();
|
|
@@ -80,7 +96,9 @@ export class Queue extends EventEmitter {
|
|
|
80
96
|
* Enqueue a job (fire-and-forget)
|
|
81
97
|
*/
|
|
82
98
|
async enqueue(id, payload, options) {
|
|
99
|
+
this.#logger.trace({ id }, 'Enqueue requested.');
|
|
83
100
|
const result = await this.#producer.enqueue(id, payload, options);
|
|
101
|
+
this.#logger.trace({ id, status: result.status }, 'Enqueue completed.');
|
|
84
102
|
if (result.status === 'queued') {
|
|
85
103
|
this.emit('enqueued', id);
|
|
86
104
|
}
|
|
@@ -90,13 +108,18 @@ export class Queue extends EventEmitter {
|
|
|
90
108
|
* Enqueue a job and wait for the result
|
|
91
109
|
*/
|
|
92
110
|
async enqueueAndWait(id, payload, options) {
|
|
93
|
-
|
|
111
|
+
this.#logger.trace({ id }, 'EnqueueAndWait requested.');
|
|
112
|
+
const result = await this.#producer.enqueueAndWait(id, payload, options);
|
|
113
|
+
this.#logger.trace({ id }, 'EnqueueAndWait resolved.');
|
|
114
|
+
return result;
|
|
94
115
|
}
|
|
95
116
|
/**
|
|
96
117
|
* Cancel a pending job
|
|
97
118
|
*/
|
|
98
119
|
async cancel(id) {
|
|
120
|
+
this.#logger.trace({ id }, 'Cancel requested.');
|
|
99
121
|
const result = await this.#producer.cancel(id);
|
|
122
|
+
this.#logger.trace({ id, status: result.status }, 'Cancel completed.');
|
|
100
123
|
if (result.status === 'cancelled') {
|
|
101
124
|
this.emit('cancelled', id);
|
|
102
125
|
}
|
|
@@ -108,6 +131,15 @@ export class Queue extends EventEmitter {
|
|
|
108
131
|
async getResult(id) {
|
|
109
132
|
return this.#producer.getResult(id);
|
|
110
133
|
}
|
|
134
|
+
/**
|
|
135
|
+
* Update TTL for a terminal job payload (result or error).
|
|
136
|
+
*/
|
|
137
|
+
async updateResultTTL(id, ttlMs) {
|
|
138
|
+
this.#logger.trace({ id, ttlMs }, 'UpdateResultTTL requested.');
|
|
139
|
+
const result = await this.#producer.updateResultTTL(id, ttlMs);
|
|
140
|
+
this.#logger.trace({ id, status: result.status }, 'UpdateResultTTL completed.');
|
|
141
|
+
return result;
|
|
142
|
+
}
|
|
111
143
|
/**
|
|
112
144
|
* Get the status of a job
|
|
113
145
|
*/
|
|
@@ -117,6 +149,7 @@ export class Queue extends EventEmitter {
|
|
|
117
149
|
#startConsumer() {
|
|
118
150
|
if (this.#consumer || !this.#handler)
|
|
119
151
|
return;
|
|
152
|
+
this.#logger.debug({ concurrency: this.#concurrency }, 'Starting consumer.');
|
|
120
153
|
this.#consumer = new Consumer({
|
|
121
154
|
storage: this.#storage,
|
|
122
155
|
workerId: this.#workerId,
|
|
@@ -126,28 +159,42 @@ export class Queue extends EventEmitter {
|
|
|
126
159
|
blockTimeout: this.#blockTimeout,
|
|
127
160
|
maxRetries: this.#maxRetries,
|
|
128
161
|
resultTTL: this.#resultTTL,
|
|
129
|
-
visibilityTimeout: this.#visibilityTimeout
|
|
162
|
+
visibilityTimeout: this.#visibilityTimeout,
|
|
163
|
+
afterExecution: this.#afterExecution,
|
|
164
|
+
logger: this.#logger
|
|
130
165
|
});
|
|
131
166
|
// Forward consumer events
|
|
132
|
-
this.#consumer.on('error',
|
|
133
|
-
this
|
|
167
|
+
this.#consumer.on('error', error => {
|
|
168
|
+
this.#emitError(error, 'Consumer emitted error.');
|
|
134
169
|
});
|
|
135
170
|
this.#consumer.on('completed', (id, result) => {
|
|
171
|
+
this.#logger.debug({ id }, 'Job completed.');
|
|
136
172
|
this.emit('completed', id, result);
|
|
137
173
|
});
|
|
138
174
|
this.#consumer.on('failed', (id, error) => {
|
|
175
|
+
this.#logger.warn({ id, err: ensureLoggableError(error) }, 'Job failed.');
|
|
139
176
|
this.emit('failed', id, error);
|
|
140
177
|
});
|
|
141
178
|
this.#consumer.on('failing', (id, error, attempt) => {
|
|
179
|
+
this.#logger.warn({ id, attempt, err: ensureLoggableError(error) }, 'Job failing and retrying.');
|
|
142
180
|
this.emit('failing', id, error, attempt);
|
|
143
181
|
});
|
|
144
|
-
this.#consumer.on('requeued',
|
|
182
|
+
this.#consumer.on('requeued', id => {
|
|
183
|
+
this.#logger.debug({ id }, 'Job requeued.');
|
|
145
184
|
this.emit('requeued', id);
|
|
146
185
|
});
|
|
147
186
|
this.#consumer.execute(this.#handler);
|
|
148
|
-
this.#consumer.start().catch(
|
|
149
|
-
this
|
|
187
|
+
this.#consumer.start().catch(err => {
|
|
188
|
+
this.#emitError(err, 'Failed to start consumer.');
|
|
150
189
|
});
|
|
151
190
|
}
|
|
191
|
+
#emitError(err, message) {
|
|
192
|
+
const error = err instanceof Error ? err : new Error(String(err));
|
|
193
|
+
if (this.listenerCount('error') > 0) {
|
|
194
|
+
this.emit('error', error);
|
|
195
|
+
return;
|
|
196
|
+
}
|
|
197
|
+
this.#logger.error({ err: ensureLoggableError(error) }, message);
|
|
198
|
+
}
|
|
152
199
|
}
|
|
153
200
|
//# sourceMappingURL=queue.js.map
|
package/dist/queue.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"queue.js","sourceRoot":"","sources":["../src/queue.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"queue.js","sourceRoot":"","sources":["../src/queue.ts"],"names":[],"mappings":"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"}
|
package/dist/reaper.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { EventEmitter } from 'node:events';
|
|
2
|
-
import type {
|
|
2
|
+
import type { Logger } from 'pino';
|
|
3
3
|
import type { Serde } from './serde/index.ts';
|
|
4
|
+
import type { Storage } from './storage/types.ts';
|
|
4
5
|
interface LeaderElectionConfig {
|
|
5
6
|
enabled: boolean;
|
|
6
7
|
lockTTL?: number;
|
|
@@ -12,6 +13,7 @@ interface ReaperConfig<TPayload> {
|
|
|
12
13
|
payloadSerde?: Serde<TPayload>;
|
|
13
14
|
visibilityTimeout?: number;
|
|
14
15
|
leaderElection?: LeaderElectionConfig;
|
|
16
|
+
logger?: Logger;
|
|
15
17
|
}
|
|
16
18
|
interface ReaperEvents {
|
|
17
19
|
error: [error: Error];
|
package/dist/reaper.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"reaper.d.ts","sourceRoot":"","sources":["../src/reaper.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"reaper.d.ts","sourceRoot":"","sources":["../src/reaper.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAC1C,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAA;AAClC,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAA;AAE7C,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAA;AAKjD,UAAU,oBAAoB;IAC5B,OAAO,EAAE,OAAO,CAAA;IAChB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,oBAAoB,CAAC,EAAE,MAAM,CAAA;CAC9B;AAED,UAAU,YAAY,CAAC,QAAQ;IAC7B,OAAO,EAAE,OAAO,CAAA;IAChB,YAAY,CAAC,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAA;IAC9B,iBAAiB,CAAC,EAAE,MAAM,CAAA;IAC1B,cAAc,CAAC,EAAE,oBAAoB,CAAA;IACrC,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB;AAED,UAAU,YAAY;IACpB,KAAK,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,CAAA;IACrB,OAAO,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC,CAAA;IACrB,kBAAkB,EAAE,EAAE,CAAA;IACtB,cAAc,EAAE,EAAE,CAAA;CACnB;AAOD;;;;;;;;GAQG;AACH,qBAAa,MAAM,CAAC,QAAQ,CAAE,SAAQ,YAAY,CAAC,YAAY,CAAC;;gBAgBjD,MAAM,EAAE,YAAY,CAAC,QAAQ,CAAC;IAU3C;;OAEG;IACH,IAAI,QAAQ,IAAK,MAAM,CAEtB;IAED;;OAEG;IACH,IAAI,QAAQ,IAAK,OAAO,CAEvB;IAED;;OAEG;IACG,KAAK,IAAK,OAAO,CAAC,IAAI,CAAC;IAa7B;;OAEG;IACG,IAAI,IAAK,OAAO,CAAC,IAAI,CAAC;CAuW7B"}
|
package/dist/reaper.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import { EventEmitter } from 'node:events';
|
|
2
1
|
import { randomUUID } from 'node:crypto';
|
|
2
|
+
import { EventEmitter } from 'node:events';
|
|
3
3
|
import { createJsonSerde } from "./serde/index.js";
|
|
4
|
+
import { abstractLogger, ensureLoggableError } from "./utils/logging.js";
|
|
4
5
|
import { parseState } from "./utils/state.js";
|
|
5
6
|
const LOCK_KEY = 'reaper:lock';
|
|
6
7
|
const DEFAULT_LOCK_TTL = 30000;
|
|
@@ -20,6 +21,7 @@ export class Reaper extends EventEmitter {
|
|
|
20
21
|
#payloadSerde;
|
|
21
22
|
#visibilityTimeout;
|
|
22
23
|
#leaderElection;
|
|
24
|
+
#logger;
|
|
23
25
|
#running = false;
|
|
24
26
|
#unsubscribe = null;
|
|
25
27
|
#processingTimers = new Map();
|
|
@@ -34,6 +36,7 @@ export class Reaper extends EventEmitter {
|
|
|
34
36
|
this.#visibilityTimeout = config.visibilityTimeout ?? 30000;
|
|
35
37
|
this.#leaderElection = config.leaderElection ?? { enabled: false };
|
|
36
38
|
this.#reaperId = randomUUID();
|
|
39
|
+
this.#logger = (config.logger ?? abstractLogger).child({ component: 'reaper', reaperId: this.#reaperId });
|
|
37
40
|
}
|
|
38
41
|
/**
|
|
39
42
|
* Get the unique identifier for this reaper instance
|
|
@@ -156,7 +159,7 @@ export class Reaper extends EventEmitter {
|
|
|
156
159
|
}
|
|
157
160
|
}
|
|
158
161
|
catch (err) {
|
|
159
|
-
this
|
|
162
|
+
this.#emitError(err, 'Leadership check failed.');
|
|
160
163
|
}
|
|
161
164
|
}, interval);
|
|
162
165
|
}
|
|
@@ -166,7 +169,7 @@ export class Reaper extends EventEmitter {
|
|
|
166
169
|
async #tryAcquireLock(ttlMs) {
|
|
167
170
|
if (!this.#storage.acquireLeaderLock) {
|
|
168
171
|
// Storage doesn't support leader election
|
|
169
|
-
this
|
|
172
|
+
this.#emitError(new Error('Storage does not support leader election'));
|
|
170
173
|
return false;
|
|
171
174
|
}
|
|
172
175
|
return this.#storage.acquireLeaderLock(LOCK_KEY, this.#reaperId, ttlMs);
|
|
@@ -232,8 +235,8 @@ export class Reaper extends EventEmitter {
|
|
|
232
235
|
this.#cancelTimer(id);
|
|
233
236
|
const timer = setTimeout(() => {
|
|
234
237
|
this.#processingTimers.delete(id);
|
|
235
|
-
this.#checkJob(id).catch(
|
|
236
|
-
this
|
|
238
|
+
this.#checkJob(id).catch(err => {
|
|
239
|
+
this.#emitError(err, 'Failed checking job after visibility timer.');
|
|
237
240
|
});
|
|
238
241
|
}, this.#visibilityTimeout);
|
|
239
242
|
this.#processingTimers.set(id, timer);
|
|
@@ -271,8 +274,8 @@ export class Reaper extends EventEmitter {
|
|
|
271
274
|
const remaining = this.#visibilityTimeout - elapsed;
|
|
272
275
|
const timer = setTimeout(() => {
|
|
273
276
|
this.#processingTimers.delete(id);
|
|
274
|
-
this.#checkJob(id).catch(
|
|
275
|
-
this
|
|
277
|
+
this.#checkJob(id).catch(err => {
|
|
278
|
+
this.#emitError(err, 'Failed re-checking job after visibility timeout.');
|
|
276
279
|
});
|
|
277
280
|
}, remaining);
|
|
278
281
|
this.#processingTimers.set(id, timer);
|
|
@@ -286,7 +289,7 @@ export class Reaper extends EventEmitter {
|
|
|
286
289
|
*/
|
|
287
290
|
async #recoverStalledJob(id, workerId) {
|
|
288
291
|
if (!workerId) {
|
|
289
|
-
this
|
|
292
|
+
this.#emitError(new Error(`Cannot recover stalled job ${id}: no workerId in state`));
|
|
290
293
|
return;
|
|
291
294
|
}
|
|
292
295
|
// Get the job from the worker's processing queue
|
|
@@ -359,8 +362,8 @@ export class Reaper extends EventEmitter {
|
|
|
359
362
|
const remaining = this.#visibilityTimeout - elapsed;
|
|
360
363
|
const timer = setTimeout(() => {
|
|
361
364
|
this.#processingTimers.delete(queueMessage.id);
|
|
362
|
-
this.#checkJob(queueMessage.id).catch(
|
|
363
|
-
this
|
|
365
|
+
this.#checkJob(queueMessage.id).catch(err => {
|
|
366
|
+
this.#emitError(err, 'Failed checking worker processing job.');
|
|
364
367
|
});
|
|
365
368
|
}, remaining);
|
|
366
369
|
this.#processingTimers.set(queueMessage.id, timer);
|
|
@@ -372,5 +375,13 @@ export class Reaper extends EventEmitter {
|
|
|
372
375
|
}
|
|
373
376
|
}
|
|
374
377
|
}
|
|
378
|
+
#emitError(err, message = 'Reaper emitted error.') {
|
|
379
|
+
const error = err instanceof Error ? err : new Error(String(err));
|
|
380
|
+
if (this.listenerCount('error') > 0) {
|
|
381
|
+
this.emit('error', error);
|
|
382
|
+
return;
|
|
383
|
+
}
|
|
384
|
+
this.#logger.error({ err: ensureLoggableError(error) }, message);
|
|
385
|
+
}
|
|
375
386
|
}
|
|
376
387
|
//# sourceMappingURL=reaper.js.map
|
package/dist/reaper.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"reaper.js","sourceRoot":"","sources":["../src/reaper.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"reaper.js","sourceRoot":"","sources":["../src/reaper.ts"],"names":[],"mappings":"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"}
|
package/dist/storage/file.d.ts
CHANGED
|
@@ -32,9 +32,12 @@ export declare class FileStorage implements Storage {
|
|
|
32
32
|
notifyJobComplete(id: string, status: 'completed' | 'failed' | 'failing'): Promise<void>;
|
|
33
33
|
subscribeToEvents(handler: (id: string, event: string) => void): Promise<() => Promise<void>>;
|
|
34
34
|
publishEvent(id: string, event: string): Promise<void>;
|
|
35
|
-
completeJob(id: string, message: Buffer, workerId: string, result: Buffer,
|
|
36
|
-
failJob(id: string, message: Buffer, workerId: string, error: Buffer,
|
|
35
|
+
completeJob(id: string, message: Buffer, workerId: string, result: Buffer, resultTTL: number): Promise<void>;
|
|
36
|
+
failJob(id: string, message: Buffer, workerId: string, error: Buffer, errorTTL: number): Promise<void>;
|
|
37
37
|
retryJob(id: string, message: Buffer, workerId: string, attempts: number): Promise<void>;
|
|
38
|
+
acquireLeaderLock(lockKey: string, ownerId: string, ttlMs: number): Promise<boolean>;
|
|
39
|
+
renewLeaderLock(lockKey: string, ownerId: string, ttlMs: number): Promise<boolean>;
|
|
40
|
+
releaseLeaderLock(lockKey: string, ownerId: string): Promise<boolean>;
|
|
38
41
|
/**
|
|
39
42
|
* Clear all data (useful for testing)
|
|
40
43
|
*/
|