You've already forked node-redis
mirror of
https://github.com/redis/node-redis.git
synced 2025-08-10 11:43:01 +03:00
another pub/sub strategy
This commit is contained in:
@@ -3,12 +3,14 @@ var json = {
|
|||||||
decode: JSON.parse
|
decode: JSON.parse
|
||||||
};
|
};
|
||||||
|
|
||||||
/*var msgpack = require('node-msgpack');
|
var MsgPack = require('node-msgpack');
|
||||||
msgpack = {
|
msgpack = {
|
||||||
encode: msgpack.pack,
|
encode: MsgPack.pack,
|
||||||
decode: msgpack.unpack
|
decode: function(str) { return MsgPack.unpack(new Buffer(str)); }
|
||||||
};*/
|
};
|
||||||
|
|
||||||
bison = require('bison');
|
bison = require('bison');
|
||||||
|
|
||||||
module.exports = json;
|
module.exports = json;
|
||||||
|
//module.exports = msgpack;
|
||||||
|
module.exports = bison;
|
||||||
|
@@ -6,8 +6,8 @@ var codec = require('../codec');
|
|||||||
var sent = 0;
|
var sent = 0;
|
||||||
|
|
||||||
var pub = require('redis').createClient(null, null, {
|
var pub = require('redis').createClient(null, null, {
|
||||||
command_queue_high_water: 5,
|
//command_queue_high_water: 5,
|
||||||
command_queue_low_water: 1
|
//command_queue_low_water: 1
|
||||||
})
|
})
|
||||||
.on('ready', function() {
|
.on('ready', function() {
|
||||||
this.emit('drain');
|
this.emit('drain');
|
||||||
|
@@ -1,13 +1,39 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
var freemem = require('os').freemem;
|
||||||
var codec = require('../codec');
|
var codec = require('../codec');
|
||||||
|
|
||||||
var pub = require('redis').createClient()
|
var sent = 0;
|
||||||
|
|
||||||
|
var pub = require('redis').createClient(null, null, {
|
||||||
|
//command_queue_high_water: 5,
|
||||||
|
//command_queue_low_water: 1
|
||||||
|
})
|
||||||
.on('ready', function() {
|
.on('ready', function() {
|
||||||
while (true) {
|
this.del('timeline');
|
||||||
pub.rpush('timeline', codec.encode({
|
this.emit('drain');
|
||||||
cmd: Math.random(),
|
})
|
||||||
data: Math.random()
|
.on('drain', function() {
|
||||||
}));
|
process.nextTick(exec);
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
var payload = '1'; for (var i = 0; i < 10; ++i) payload += payload;
|
||||||
|
|
||||||
|
function exec() {
|
||||||
|
pub.rpush('timeline', codec.encode({ foo: payload }));
|
||||||
|
++sent;
|
||||||
|
if (!pub.should_buffer) {
|
||||||
|
process.nextTick(exec);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
exec();
|
||||||
|
|
||||||
|
setInterval(function() {
|
||||||
|
pub.llen('timeline', function(err, result) {
|
||||||
|
console.log('sent', sent, 'free', freemem(),
|
||||||
|
'cmdqlen', pub.command_queue.length, 'offqlen', pub.offline_queue.length,
|
||||||
|
'llen', result
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}, 1000);
|
||||||
|
Reference in New Issue
Block a user