2023-01-13 04:40:33 +00:00
|
|
|
import Xev from "xev";
|
|
|
|
import { deliverQueue, inboxQueue } from "../queue/queues.js";
|
2019-03-10 10:16:33 +00:00
|
|
|
|
2022-04-17 05:42:13 +00:00
|
|
|
const ev = new Xev();
|
2019-03-10 10:16:33 +00:00
|
|
|
|
2020-01-29 19:37:25 +00:00
|
|
|
const interval = 10000;
|
2019-03-10 10:16:33 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Report queue stats regularly
|
|
|
|
*/
|
2023-01-13 04:40:33 +00:00
|
|
|
export default function () {
|
2020-01-29 19:37:25 +00:00
|
|
|
const log = [] as any[];
|
2019-03-10 10:16:33 +00:00
|
|
|
|
2023-01-13 04:40:33 +00:00
|
|
|
ev.on("requestQueueStatsLog", (x) => {
|
2020-01-29 19:37:25 +00:00
|
|
|
ev.emit(`queueStatsLog:${x.id}`, log.slice(0, x.length || 50));
|
2019-03-10 10:16:33 +00:00
|
|
|
});
|
|
|
|
|
2019-03-12 01:35:17 +00:00
|
|
|
let activeDeliverJobs = 0;
|
|
|
|
let activeInboxJobs = 0;
|
|
|
|
|
2023-01-13 04:40:33 +00:00
|
|
|
deliverQueue.on("global:active", () => {
|
2019-03-12 01:35:17 +00:00
|
|
|
activeDeliverJobs++;
|
|
|
|
});
|
|
|
|
|
2023-01-13 04:40:33 +00:00
|
|
|
inboxQueue.on("global:active", () => {
|
2019-03-12 01:35:17 +00:00
|
|
|
activeInboxJobs++;
|
|
|
|
});
|
|
|
|
|
2019-03-10 10:16:33 +00:00
|
|
|
async function tick() {
|
|
|
|
const deliverJobCounts = await deliverQueue.getJobCounts();
|
|
|
|
const inboxJobCounts = await inboxQueue.getJobCounts();
|
|
|
|
|
|
|
|
const stats = {
|
2019-03-12 01:35:17 +00:00
|
|
|
deliver: {
|
2019-03-12 03:31:01 +00:00
|
|
|
activeSincePrevTick: activeDeliverJobs,
|
|
|
|
active: deliverJobCounts.active,
|
2019-03-12 01:35:17 +00:00
|
|
|
waiting: deliverJobCounts.waiting,
|
2021-12-09 14:58:30 +00:00
|
|
|
delayed: deliverJobCounts.delayed,
|
2019-03-12 01:35:17 +00:00
|
|
|
},
|
|
|
|
inbox: {
|
2019-03-12 03:31:01 +00:00
|
|
|
activeSincePrevTick: activeInboxJobs,
|
|
|
|
active: inboxJobCounts.active,
|
2019-03-12 01:35:17 +00:00
|
|
|
waiting: inboxJobCounts.waiting,
|
2021-12-09 14:58:30 +00:00
|
|
|
delayed: inboxJobCounts.delayed,
|
2019-05-27 08:23:05 +00:00
|
|
|
},
|
2019-03-10 10:16:33 +00:00
|
|
|
};
|
|
|
|
|
2023-01-13 04:40:33 +00:00
|
|
|
ev.emit("queueStats", stats);
|
2019-03-10 10:16:33 +00:00
|
|
|
|
|
|
|
log.unshift(stats);
|
|
|
|
if (log.length > 200) log.pop();
|
2019-03-12 01:35:17 +00:00
|
|
|
|
|
|
|
activeDeliverJobs = 0;
|
|
|
|
activeInboxJobs = 0;
|
2019-03-10 10:16:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
tick();
|
|
|
|
|
|
|
|
setInterval(tick, interval);
|
|
|
|
}
|