aboutsummaryrefslogtreecommitdiffstats
path: root/signaling-server/node_modules/socket.io/node_modules/redis/benches/stress/rpushblpop/pub.js
blob: 9caf1d0b82374d0c507483d736d8c8bab42dc742 (plain)
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
'use strict';

var freemem = require('os').freemem;
//var profiler = require('v8-profiler');
var codec = require('../codec');

var sent = 0;

var pub = require('redis').createClient(null, null, {
	//command_queue_high_water: 5,
	//command_queue_low_water: 1
})
.on('ready', function() {
	this.del('timeline');
	this.emit('drain');
})
.on('drain', function() {
	process.nextTick(exec);
});

var payload = '1'; for (var i = 0; i < 12; ++i) payload += payload;
console.log('Message payload length', payload.length);

function exec() {
	pub.rpush('timeline', codec.encode({ foo: payload }));
	++sent;
	if (!pub.should_buffer) {
		process.nextTick(exec);
	}
}

//profiler.takeSnapshot('s_0');

exec();

setInterval(function() {
	//var ss = profiler.takeSnapshot('s_' + sent);
	//console.error(ss.stringify());
	pub.llen('timeline', function(err, result) {
		console.error('sent', sent, 'free', freemem(),
			'cmdqlen', pub.command_queue.length, 'offqlen', pub.offline_queue.length,
			'llen', result
		);
	});
}, 2000);

/*setTimeout(function() {
	process.exit();
}, 30000);*/