sharkey/src/queue/index.ts

53 lines
1.2 KiB
TypeScript
Raw Normal View History

2018-04-04 23:12:35 +09:00
import { createQueue } from 'kue';
2018-04-05 18:43:06 +09:00
import * as debug from 'debug';
2018-04-04 23:12:35 +09:00
import config from '../config';
import db from './processors/db';
import http from './processors/http';
2018-04-05 18:43:06 +09:00
const log = debug('misskey:queue');
2018-04-04 23:12:35 +09:00
const queue = createQueue({
redis: {
port: config.redis.port,
host: config.redis.host,
auth: config.redis.pass
}
});
export function createHttp(data) {
2018-04-05 18:43:06 +09:00
log(`HTTP job created: ${JSON.stringify(data)}`);
2018-04-04 23:12:35 +09:00
return queue
.create('http', data)
.attempts(16)
.backoff({ delay: 16384, type: 'exponential' });
}
export function createDb(data) {
return queue.create('db', data);
}
2018-04-05 23:24:51 +09:00
export function deliver(user, content, to) {
return createHttp({
type: 'deliver',
user,
content,
to
});
}
2018-04-05 18:43:06 +09:00
export default function() {
2018-04-04 23:12:35 +09:00
queue.process('db', db);
/*
256 is the default concurrency limit of Mozilla Firefox and Google
Chromium.
a8af215e691f3a2205a3758d2d96e9d328e100ff - chromium/src.git - Git at Google
https://chromium.googlesource.com/chromium/src.git/+/a8af215e691f3a2205a3758d2d96e9d328e100ff
Network.http.max-connections - MozillaZine Knowledge Base
http://kb.mozillazine.org/Network.http.max-connections
*/
queue.process('http', 256, http);
}