-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathserver.js
79 lines (69 loc) · 2.47 KB
/
server.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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
var url = require('url')
, http = require('http')
, crypto = require('crypto')
, io = require('socket.io')
, redisClient = require('redis-client').createClient
, config = require('./config')
, varnish = new(require('./varnish-ext/build/default/varnish').Varnish)('/tmp')
, frontend = new(require('http').Server)()
, staticSrv = new(require('node-static').Server)('./public')
, twitter = require('./lib/twitter').createStream(config.twitter)
, varnishCli = http.createClient(config.varnish.port, config.varnish.host)
, socket = io.listen(frontend)
, statFields = config.varnish.statFields
, lastStats = null
, urlHash = function(x) { return crypto.createHash('md5').update(x).digest('hex') }
// handle static file requests
frontend
.on('request', function (req, res) {
req.on('end', function () {
staticSrv.serve(req, res)
})
})
.listen(config.frontend.port)
// accepting socket connections and broadcast events
socket
.on('connection', function (client) {
client.broadcast({ announcement: client.sessionId + ' connected' })
})
// generate varnish requests from bit.ly urls
twitter
.on('urls', function (urls) {
urls.forEach(function(url) {
var request = varnishCli.request('GET', '/' + url, { host: config.varnish.host })
varnishCli.on('error', function (err) { console.log(err.stack) })
request.on('error', function (err) { console.log(err.stack) })
request.end()
})
})
.on('error', function(err) {
throw err
})
// generate varnish traffic
varnish
.on('RxURL', function (tag, fd, spec, url) {
var pack = { key: 'request'
, value: { url: ('http:/' + url)
, hash: urlHash(url.toString())
}
}
socket.broadcast(JSON.stringify(pack))
})
// generate stat events and broadcast to all clients
setInterval(function () {
var currentStats = varnish.stats()
for (var i=0; i< statFields.length; i++) {
socket.broadcast(
JSON.stringify({ key: statFields[i]
, value: { ag: currentStats[statFields[i]]
, av: (lastStats ? currentStats[statFields[i]] - lastStats[statFields[i]] : currentStats[statFields[i]]) * 10
}
})
)
}
lastStats = currentStats
}, 1000)
// generate log events and broadcast to all clients
setInterval(function() {
varnish.listen()
}, 50)