2021-05-08 11:56:21 +02:00
|
|
|
import * as Bull from 'bull';
|
2021-08-19 14:55:45 +02:00
|
|
|
import config from '@/config/index';
|
2021-03-18 03:17:05 +01:00
|
|
|
|
2021-05-08 11:56:21 +02:00
|
|
|
export function initialize<T>(name: string, limitPerSec = -1) {
|
|
|
|
return new Bull<T>(name, {
|
2021-03-18 03:17:05 +01:00
|
|
|
redis: {
|
|
|
|
port: config.redis.port,
|
|
|
|
host: config.redis.host,
|
|
|
|
password: config.redis.pass,
|
|
|
|
db: config.redis.db || 0,
|
|
|
|
},
|
|
|
|
prefix: config.redis.prefix ? `${config.redis.prefix}:queue` : 'queue',
|
|
|
|
limiter: limitPerSec > 0 ? {
|
2021-08-20 14:59:03 +02:00
|
|
|
max: limitPerSec,
|
|
|
|
duration: 1000
|
|
|
|
} : undefined,
|
|
|
|
settings: {
|
|
|
|
backoffStrategies: {
|
|
|
|
apBackoff
|
|
|
|
}
|
|
|
|
}
|
2021-03-18 03:17:05 +01:00
|
|
|
});
|
|
|
|
}
|
2021-08-20 14:59:03 +02:00
|
|
|
|
|
|
|
// ref. https://github.com/misskey-dev/misskey/pull/7635#issue-971097019
|
|
|
|
function apBackoff(attemptsMade: number, err: Error) {
|
|
|
|
const baseDelay = 60 * 1000; // 1min
|
|
|
|
const maxBackoff = 8 * 60 * 60 * 1000; // 8hours
|
|
|
|
let backoff = (Math.pow(2, attemptsMade) - 1) * baseDelay;
|
|
|
|
backoff = Math.min(backoff, maxBackoff);
|
|
|
|
backoff += Math.round(backoff * Math.random() * 0.2);
|
|
|
|
return backoff;
|
|
|
|
}
|