redis-smq-benchmarks 9.0.9-next.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/CHANGELOG.md +19 -0
- package/LICENSE +22 -0
- package/README.md +192 -0
- package/README.template.md +186 -0
- package/dist/esm/bin/cli.d.ts +2 -0
- package/dist/esm/bin/cli.d.ts.map +1 -0
- package/dist/esm/bin/cli.js +121 -0
- package/dist/esm/bin/cli.js.map +1 -0
- package/dist/esm/index.d.ts +2 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +2 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/src/common/base-benchmark.d.ts +39 -0
- package/dist/esm/src/common/base-benchmark.d.ts.map +1 -0
- package/dist/esm/src/common/base-benchmark.js +83 -0
- package/dist/esm/src/common/base-benchmark.js.map +1 -0
- package/dist/esm/src/common/redis-server.d.ts +13 -0
- package/dist/esm/src/common/redis-server.d.ts.map +1 -0
- package/dist/esm/src/common/redis-server.js +22 -0
- package/dist/esm/src/common/redis-server.js.map +1 -0
- package/dist/esm/src/consumer-benchmark.d.ts +9 -0
- package/dist/esm/src/consumer-benchmark.d.ts.map +1 -0
- package/dist/esm/src/consumer-benchmark.js +61 -0
- package/dist/esm/src/consumer-benchmark.js.map +1 -0
- package/dist/esm/src/e2e-benchmark.d.ts +4 -0
- package/dist/esm/src/e2e-benchmark.d.ts.map +1 -0
- package/dist/esm/src/e2e-benchmark.js +159 -0
- package/dist/esm/src/e2e-benchmark.js.map +1 -0
- package/dist/esm/src/helpers/create-worker.d.ts +13 -0
- package/dist/esm/src/helpers/create-worker.d.ts.map +1 -0
- package/dist/esm/src/helpers/create-worker.js +24 -0
- package/dist/esm/src/helpers/create-worker.js.map +1 -0
- package/dist/esm/src/helpers/ensure-queue.d.ts +4 -0
- package/dist/esm/src/helpers/ensure-queue.d.ts.map +1 -0
- package/dist/esm/src/helpers/ensure-queue.js +10 -0
- package/dist/esm/src/helpers/ensure-queue.js.map +1 -0
- package/dist/esm/src/helpers/prefill-queue.d.ts +4 -0
- package/dist/esm/src/helpers/prefill-queue.d.ts.map +1 -0
- package/dist/esm/src/helpers/prefill-queue.js +23 -0
- package/dist/esm/src/helpers/prefill-queue.js.map +1 -0
- package/dist/esm/src/producer-benchmark.d.ts +8 -0
- package/dist/esm/src/producer-benchmark.d.ts.map +1 -0
- package/dist/esm/src/producer-benchmark.js +47 -0
- package/dist/esm/src/producer-benchmark.js.map +1 -0
- package/dist/esm/src/threads/consumer-worker-thread.d.ts +2 -0
- package/dist/esm/src/threads/consumer-worker-thread.d.ts.map +1 -0
- package/dist/esm/src/threads/consumer-worker-thread.js +59 -0
- package/dist/esm/src/threads/consumer-worker-thread.js.map +1 -0
- package/dist/esm/src/threads/producer-worker-thread.d.ts +2 -0
- package/dist/esm/src/threads/producer-worker-thread.d.ts.map +1 -0
- package/dist/esm/src/threads/producer-worker-thread.js +54 -0
- package/dist/esm/src/threads/producer-worker-thread.js.map +1 -0
- package/dist/esm/src/types/index.d.ts +57 -0
- package/dist/esm/src/types/index.d.ts.map +1 -0
- package/dist/esm/src/types/index.js +6 -0
- package/dist/esm/src/types/index.js.map +1 -0
- package/package.json +69 -0
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { parentPort, workerData } from 'worker_threads';
|
|
2
|
+
import { RedisSMQ } from 'redis-smq';
|
|
3
|
+
import { async } from 'redis-smq-common';
|
|
4
|
+
import { EWorkerMessageType } from '../types/index.js';
|
|
5
|
+
const { queue, redisConfig, workerId, expectedMessages } = workerData;
|
|
6
|
+
let consumedCount = 0;
|
|
7
|
+
let startTime = 0;
|
|
8
|
+
RedisSMQ.initialize(redisConfig, (err) => {
|
|
9
|
+
if (err)
|
|
10
|
+
throw err;
|
|
11
|
+
const consumer = RedisSMQ.createConsumer();
|
|
12
|
+
async.series([
|
|
13
|
+
(cb) => consumer.run(cb),
|
|
14
|
+
(cb) => {
|
|
15
|
+
startTime = Date.now();
|
|
16
|
+
consumer.consume(queue, (_msg, ack) => {
|
|
17
|
+
consumedCount++;
|
|
18
|
+
ack();
|
|
19
|
+
if (expectedMessages > 0 &&
|
|
20
|
+
consumedCount % Math.max(1, Math.floor(expectedMessages / 10)) ===
|
|
21
|
+
0) {
|
|
22
|
+
parentPort?.postMessage({
|
|
23
|
+
type: EWorkerMessageType.PROGRESS,
|
|
24
|
+
data: { workerId, processed: consumedCount },
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
if (expectedMessages > 0 && consumedCount >= expectedMessages) {
|
|
28
|
+
const timeTaken = Date.now() - startTime;
|
|
29
|
+
consumer.cancel(queue, (err) => {
|
|
30
|
+
if (err) {
|
|
31
|
+
console.error(`Worker ${workerId} error cancelling consumer:`, err);
|
|
32
|
+
return cb(err);
|
|
33
|
+
}
|
|
34
|
+
parentPort?.postMessage({
|
|
35
|
+
type: EWorkerMessageType.COMPLETED,
|
|
36
|
+
data: {
|
|
37
|
+
workerId,
|
|
38
|
+
processed: consumedCount,
|
|
39
|
+
timeTaken,
|
|
40
|
+
expected: expectedMessages,
|
|
41
|
+
},
|
|
42
|
+
});
|
|
43
|
+
cb();
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
}, (err) => {
|
|
47
|
+
if (err)
|
|
48
|
+
cb(err);
|
|
49
|
+
});
|
|
50
|
+
},
|
|
51
|
+
], (err) => {
|
|
52
|
+
if (err) {
|
|
53
|
+
console.error(`Worker ${workerId} error:`, err);
|
|
54
|
+
throw err;
|
|
55
|
+
}
|
|
56
|
+
RedisSMQ.shutdown(() => void 0);
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
//# sourceMappingURL=consumer-worker-thread.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"consumer-worker-thread.js","sourceRoot":"","sources":["../../../../src/threads/consumer-worker-thread.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACxD,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AACrC,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AACzC,OAAO,EAAE,kBAAkB,EAAe,MAAM,mBAAmB,CAAC;AAEpE,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,QAAQ,EAAE,gBAAgB,EAAE,GACtD,UAAyB,CAAC;AAE5B,IAAI,aAAa,GAAG,CAAC,CAAC;AACtB,IAAI,SAAS,GAAG,CAAC,CAAC;AAElB,QAAQ,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC,GAAG,EAAE,EAAE;IACvC,IAAI,GAAG;QAAE,MAAM,GAAG,CAAC;IACnB,MAAM,QAAQ,GAAG,QAAQ,CAAC,cAAc,EAAE,CAAC;IAE3C,KAAK,CAAC,MAAM,CACV;QACE,CAAC,EAAE,EAAE,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;QACxB,CAAC,EAAE,EAAE,EAAE;YACL,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACvB,QAAQ,CAAC,OAAO,CACd,KAAK,EACL,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE;gBACZ,aAAa,EAAE,CAAC;gBAChB,GAAG,EAAE,CAAC;gBAGN,IACE,gBAAgB,GAAG,CAAC;oBACpB,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,gBAAgB,GAAG,EAAE,CAAC,CAAC;wBAC5D,CAAC,EACH,CAAC;oBACD,UAAU,EAAE,WAAW,CAAC;wBACtB,IAAI,EAAE,kBAAkB,CAAC,QAAQ;wBACjC,IAAI,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,aAAa,EAAE;qBAC7C,CAAC,CAAC;gBACL,CAAC;gBAGD,IAAI,gBAAgB,GAAG,CAAC,IAAI,aAAa,IAAI,gBAAgB,EAAE,CAAC;oBAC9D,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;oBACzC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,GAAG,EAAE,EAAE;wBAC7B,IAAI,GAAG,EAAE,CAAC;4BACR,OAAO,CAAC,KAAK,CACX,UAAU,QAAQ,6BAA6B,EAC/C,GAAG,CACJ,CAAC;4BACF,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC;wBACjB,CAAC;wBACD,UAAU,EAAE,WAAW,CAAC;4BACtB,IAAI,EAAE,kBAAkB,CAAC,SAAS;4BAClC,IAAI,EAAE;gCACJ,QAAQ;gCACR,SAAS,EAAE,aAAa;gCACxB,SAAS;gCACT,QAAQ,EAAE,gBAAgB;6BAC3B;yBACF,CAAC,CAAC;wBACH,EAAE,EAAE,CAAC;oBACP,CAAC,CAAC,CAAC;gBACL,CAAC;YACH,CAAC,EACD,CAAC,GAAG,EAAE,EAAE;gBACN,IAAI,GAAG;oBAAE,EAAE,CAAC,GAAG,CAAC,CAAC;YACnB,CAAC,CACF,CAAC;QACJ,CAAC;KACF,EACD,CAAC,GAAG,EAAE,EAAE;QACN,IAAI,GAAG,EAAE,CAAC;YACR,OAAO,CAAC,KAAK,CAAC,UAAU,QAAQ,SAAS,EAAE,GAAG,CAAC,CAAC;YAChD,MAAM,GAAG,CAAC;QACZ,CAAC;QACD,QAAQ,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IAClC,CAAC,CACF,CAAC;AACJ,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"producer-worker-thread.d.ts","sourceRoot":"","sources":["../../../../src/threads/producer-worker-thread.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { parentPort, workerData } from 'worker_threads';
|
|
2
|
+
import { ProducibleMessage, RedisSMQ } from 'redis-smq';
|
|
3
|
+
import { async } from 'redis-smq-common';
|
|
4
|
+
import { EWorkerMessageType } from '../types/index.js';
|
|
5
|
+
const { queue, redisConfig, workerId, expectedMessages } = workerData;
|
|
6
|
+
let producedCount = 0;
|
|
7
|
+
let startTime = 0;
|
|
8
|
+
RedisSMQ.initialize(redisConfig, (err) => {
|
|
9
|
+
if (err)
|
|
10
|
+
throw err;
|
|
11
|
+
const producer = RedisSMQ.createProducer();
|
|
12
|
+
async.series([
|
|
13
|
+
(cb) => producer.run(cb),
|
|
14
|
+
(cb) => {
|
|
15
|
+
startTime = Date.now();
|
|
16
|
+
const pump = () => {
|
|
17
|
+
if (producedCount < expectedMessages) {
|
|
18
|
+
producedCount++;
|
|
19
|
+
const msg = new ProducibleMessage()
|
|
20
|
+
.setQueue(queue)
|
|
21
|
+
.setBody(`m${producedCount}`);
|
|
22
|
+
producer.produce(msg, (perr) => {
|
|
23
|
+
if (perr)
|
|
24
|
+
return cb(perr);
|
|
25
|
+
pump();
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
else if (producedCount >= expectedMessages) {
|
|
29
|
+
const timeTaken = Date.now() - startTime;
|
|
30
|
+
parentPort?.postMessage({
|
|
31
|
+
type: EWorkerMessageType.COMPLETED,
|
|
32
|
+
data: {
|
|
33
|
+
workerId,
|
|
34
|
+
processed: producedCount,
|
|
35
|
+
timeTaken,
|
|
36
|
+
expected: expectedMessages,
|
|
37
|
+
},
|
|
38
|
+
});
|
|
39
|
+
return cb();
|
|
40
|
+
}
|
|
41
|
+
else
|
|
42
|
+
cb();
|
|
43
|
+
};
|
|
44
|
+
pump();
|
|
45
|
+
},
|
|
46
|
+
], (err) => {
|
|
47
|
+
if (err) {
|
|
48
|
+
console.error(`Worker ${workerId} error:`, err);
|
|
49
|
+
throw err;
|
|
50
|
+
}
|
|
51
|
+
RedisSMQ.shutdown(() => void 0);
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
//# sourceMappingURL=producer-worker-thread.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"producer-worker-thread.js","sourceRoot":"","sources":["../../../../src/threads/producer-worker-thread.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACxD,OAAO,EAAE,iBAAiB,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AACxD,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AACzC,OAAO,EAAE,kBAAkB,EAAe,MAAM,mBAAmB,CAAC;AAEpE,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,QAAQ,EAAE,gBAAgB,EAAE,GACtD,UAAyB,CAAC;AAE5B,IAAI,aAAa,GAAG,CAAC,CAAC;AACtB,IAAI,SAAS,GAAG,CAAC,CAAC;AAElB,QAAQ,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC,GAAG,EAAE,EAAE;IACvC,IAAI,GAAG;QAAE,MAAM,GAAG,CAAC;IACnB,MAAM,QAAQ,GAAG,QAAQ,CAAC,cAAc,EAAE,CAAC;IAE3C,KAAK,CAAC,MAAM,CACV;QACE,CAAC,EAAE,EAAE,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;QACxB,CAAC,EAAE,EAAE,EAAE;YACL,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACvB,MAAM,IAAI,GAAG,GAAG,EAAE;gBAChB,IAAI,aAAa,GAAG,gBAAgB,EAAE,CAAC;oBACrC,aAAa,EAAE,CAAC;oBAChB,MAAM,GAAG,GAAG,IAAI,iBAAiB,EAAE;yBAChC,QAAQ,CAAC,KAAK,CAAC;yBACf,OAAO,CAAC,IAAI,aAAa,EAAE,CAAC,CAAC;oBAChC,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,IAAI,EAAE,EAAE;wBAC7B,IAAI,IAAI;4BAAE,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;wBAC1B,IAAI,EAAE,CAAC;oBACT,CAAC,CAAC,CAAC;gBACL,CAAC;qBAGI,IAAI,aAAa,IAAI,gBAAgB,EAAE,CAAC;oBAC3C,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;oBACzC,UAAU,EAAE,WAAW,CAAC;wBACtB,IAAI,EAAE,kBAAkB,CAAC,SAAS;wBAClC,IAAI,EAAE;4BACJ,QAAQ;4BACR,SAAS,EAAE,aAAa;4BACxB,SAAS;4BACT,QAAQ,EAAE,gBAAgB;yBAC3B;qBACF,CAAC,CAAC;oBACH,OAAO,EAAE,EAAE,CAAC;gBACd,CAAC;;oBAGI,EAAE,EAAE,CAAC;YACZ,CAAC,CAAC;YACF,IAAI,EAAE,CAAC;QACT,CAAC;KACF,EACD,CAAC,GAAG,EAAE,EAAE;QACN,IAAI,GAAG,EAAE,CAAC;YACR,OAAO,CAAC,KAAK,CAAC,UAAU,QAAQ,SAAS,EAAE,GAAG,CAAC,CAAC;YAChD,MAAM,GAAG,CAAC;QACZ,CAAC;QACD,QAAQ,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IAClC,CAAC,CACF,CAAC;AACJ,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { IQueueParams } from 'redis-smq';
|
|
2
|
+
import { IRedisConfig } from 'redis-smq-common';
|
|
3
|
+
export declare enum EWorkerMessageType {
|
|
4
|
+
PROGRESS = "PROGRESS",
|
|
5
|
+
COMPLETED = "COMPLETED"
|
|
6
|
+
}
|
|
7
|
+
export interface IWorkerMessageData {
|
|
8
|
+
workerId: number;
|
|
9
|
+
processed: number;
|
|
10
|
+
timeTaken: number;
|
|
11
|
+
expected: number;
|
|
12
|
+
}
|
|
13
|
+
export interface IWorkerData {
|
|
14
|
+
queue: IQueueParams;
|
|
15
|
+
redisConfig: IRedisConfig;
|
|
16
|
+
workerId: number;
|
|
17
|
+
expectedMessages: number;
|
|
18
|
+
}
|
|
19
|
+
export interface IWorkerMessage {
|
|
20
|
+
type: EWorkerMessageType;
|
|
21
|
+
data: IWorkerMessageData;
|
|
22
|
+
}
|
|
23
|
+
export interface IBenchmarkConfig {
|
|
24
|
+
redisConfig: IRedisConfig;
|
|
25
|
+
queue: IQueueParams;
|
|
26
|
+
totalMessages: number;
|
|
27
|
+
workerCount: number;
|
|
28
|
+
workerPath: string;
|
|
29
|
+
workerLabel: string;
|
|
30
|
+
showProgress: boolean;
|
|
31
|
+
}
|
|
32
|
+
export interface IE2EBenchmarkConfig {
|
|
33
|
+
redisConfig: IRedisConfig;
|
|
34
|
+
queue: IQueueParams;
|
|
35
|
+
totalMessages: number;
|
|
36
|
+
consumerCount: number;
|
|
37
|
+
consumerWorkerPath: string;
|
|
38
|
+
producerCount: number;
|
|
39
|
+
producerWorkerPath: string;
|
|
40
|
+
showProgress: boolean;
|
|
41
|
+
}
|
|
42
|
+
export interface IBenchmarkResult {
|
|
43
|
+
total: number;
|
|
44
|
+
totalTime: number;
|
|
45
|
+
totalWorkerTime: number;
|
|
46
|
+
workerCount: number;
|
|
47
|
+
}
|
|
48
|
+
export interface IE2EBenchmarkResult extends IBenchmarkResult {
|
|
49
|
+
productionTime: number;
|
|
50
|
+
consumptionTime: number;
|
|
51
|
+
messagesProduced: number;
|
|
52
|
+
messagesConsumed: number;
|
|
53
|
+
endToEndLatency?: number;
|
|
54
|
+
productionThroughput: number;
|
|
55
|
+
consumptionThroughput: number;
|
|
56
|
+
}
|
|
57
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/types/index.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAEhD,oBAAY,kBAAkB;IAC5B,QAAQ,aAAa;IACrB,SAAS,cAAc;CACxB;AAED,MAAM,WAAW,kBAAkB;IACjC,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,YAAY,CAAC;IACpB,WAAW,EAAE,YAAY,CAAC;IAC1B,QAAQ,EAAE,MAAM,CAAC;IACjB,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAED,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,kBAAkB,CAAC;IACzB,IAAI,EAAE,kBAAkB,CAAC;CAC1B;AAED,MAAM,WAAW,gBAAgB;IAC/B,WAAW,EAAE,YAAY,CAAC;IAC1B,KAAK,EAAE,YAAY,CAAC;IACpB,aAAa,EAAE,MAAM,CAAC;IACtB,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,OAAO,CAAC;CACvB;AAED,MAAM,WAAW,mBAAmB;IAClC,WAAW,EAAE,YAAY,CAAC;IAC1B,KAAK,EAAE,YAAY,CAAC;IACpB,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;IACtB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,aAAa,EAAE,MAAM,CAAC;IACtB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,YAAY,EAAE,OAAO,CAAC;CACvB;AAED,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,eAAe,EAAE,MAAM,CAAC;IACxB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,mBAAoB,SAAQ,gBAAgB;IAC3D,cAAc,EAAE,MAAM,CAAC;IACvB,eAAe,EAAE,MAAM,CAAC;IACxB,gBAAgB,EAAE,MAAM,CAAC;IACzB,gBAAgB,EAAE,MAAM,CAAC;IACzB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,oBAAoB,EAAE,MAAM,CAAC;IAC7B,qBAAqB,EAAE,MAAM,CAAC;CAC/B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/types/index.ts"],"names":[],"mappings":"AAYA,MAAM,CAAN,IAAY,kBAGX;AAHD,WAAY,kBAAkB;IAC5B,2CAAqB,CAAA;IACrB,6CAAuB,CAAA;AACzB,CAAC,EAHW,kBAAkB,KAAlB,kBAAkB,QAG7B"}
|
package/package.json
ADDED
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "redis-smq-benchmarks",
|
|
3
|
+
"version": "9.0.9-next.0",
|
|
4
|
+
"description": "Benchmarking tool for RedisSMQ to assess performance and throughput in your application environment.",
|
|
5
|
+
"author": "Weyoss <weyoss@outlook.com>",
|
|
6
|
+
"license": "MIT",
|
|
7
|
+
"keywords": [
|
|
8
|
+
"redis",
|
|
9
|
+
"redis-smq",
|
|
10
|
+
"smq",
|
|
11
|
+
"message-queue",
|
|
12
|
+
"message-broker",
|
|
13
|
+
"job-queue",
|
|
14
|
+
"priority-queue",
|
|
15
|
+
"scheduler",
|
|
16
|
+
"broker",
|
|
17
|
+
"fifo",
|
|
18
|
+
"lifo",
|
|
19
|
+
"jobs",
|
|
20
|
+
"benchmark"
|
|
21
|
+
],
|
|
22
|
+
"homepage": "https://github.com/weyoss/redis-smq",
|
|
23
|
+
"publishConfig": {
|
|
24
|
+
"registry": "https://registry.npmjs.org"
|
|
25
|
+
},
|
|
26
|
+
"repository": {
|
|
27
|
+
"type": "git",
|
|
28
|
+
"url": "https://github.com/weyoss/redis-smq.git"
|
|
29
|
+
},
|
|
30
|
+
"bugs": {
|
|
31
|
+
"url": "https://github.com/weyoss/redis-smq/issues"
|
|
32
|
+
},
|
|
33
|
+
"type": "module",
|
|
34
|
+
"module": "./dist/esm/index.js",
|
|
35
|
+
"types": "./dist/esm/index.d.ts",
|
|
36
|
+
"exports": {
|
|
37
|
+
".": {
|
|
38
|
+
"import": {
|
|
39
|
+
"types": "./dist/esm/index.d.ts",
|
|
40
|
+
"default": "./dist/esm/index.js"
|
|
41
|
+
}
|
|
42
|
+
},
|
|
43
|
+
"./package.json": "./package.json"
|
|
44
|
+
},
|
|
45
|
+
"typesVersions": {
|
|
46
|
+
"*": {
|
|
47
|
+
".": [
|
|
48
|
+
"./dist/types/index.d.ts"
|
|
49
|
+
]
|
|
50
|
+
}
|
|
51
|
+
},
|
|
52
|
+
"peerDependencies": {
|
|
53
|
+
"redis-smq": "^9.0.9-next.0",
|
|
54
|
+
"redis-smq-common": "^9.0.9-next.0"
|
|
55
|
+
},
|
|
56
|
+
"dependencies": {
|
|
57
|
+
"ioredis": "^5"
|
|
58
|
+
},
|
|
59
|
+
"bin": {
|
|
60
|
+
"redis-smq-benchmarks": "./dist/esm/bin/cli.js"
|
|
61
|
+
},
|
|
62
|
+
"engineStrict": true,
|
|
63
|
+
"engines": {
|
|
64
|
+
"node": ">=20"
|
|
65
|
+
},
|
|
66
|
+
"scripts": {
|
|
67
|
+
"build": "scripts/build.sh"
|
|
68
|
+
}
|
|
69
|
+
}
|