forked from pbattisson/AMQPTest
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
48 lines (36 loc) · 1.19 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
var logger = require('logfmt');
var jackrabbit = require('jackrabbit');
var express = require('express');
var throng = require('throng');
var cpus = require('os').cpus().length;
var RABBIT_URL = process.env.CLOUDAMQP_URL || 'amqp://localhost';
var SERVICE_TIME = process.env.SERVICE_TIME || 500;
throng(start, { workers: cpus, lifetime: Infinity });
function start() {
logger.log({ type: 'info', message: 'starting server' });
app = express();
broker = jackrabbit(RABBIT_URL, 1);
broker.once('connected', listen);
broker.once('disconnected', exit.bind(this, 'disconnected'));
process.on('SIGTERM', exit);
app.get('/info', function(req, res){
broker.publish('info.get', {}, function onInfo(err, retInfo) {
res.send(retInfo);
});
});
app.get('/time', function(req, res){
broker.publish('time.get', {}, function onTime(err, retTime) {
res.send(retTime);
});
});
app.listen(8080);
function listen() {
broker.create('info.get');
broker.create('time.get');
}
function exit(reason) {
logger.log({ type: 'info', message: 'closing server', reason: reason });
if (server) server.close(process.exit.bind(process));
else process.exit();
}
}