1
0
mirror of https://github.com/redis/node-redis.git synced 2025-08-06 02:15:48 +03:00

fix for buffered_writes -- now drain event works

This commit is contained in:
Vladimir Dronnikov
2011-07-01 03:46:50 -04:00
parent 02c3b01f0e
commit 9a4e51ee40
2 changed files with 30 additions and 10 deletions

View File

@@ -286,7 +286,7 @@ RedisClient.prototype.send_offline_queue = function () {
this.offline_queue = new Queue();
// Even though items were shifted off, Queue backing store still uses memory until next add, so just get a new Queue
if (buffered_writes === 0) {
if (!buffered_writes) {
this.should_buffer = false;
this.emit("drain");
}

View File

@@ -1,13 +1,33 @@
'use strict';
var freemem = require('os').freemem;
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() {
while (true) {
pub.publish('timeline', codec.encode({
cmd: Math.random(),
data: Math.random()
}));
}
this.emit('drain');
})
.on('drain', function() {
process.nextTick(exec);
});
var payload = '1'; for (var i = 0; i < 10; ++i) payload += payload;
function exec() {
pub.publish('timeline', codec.encode({ foo: payload }));
++sent;
if (!pub.should_buffer) {
process.nextTick(exec);
}
}
exec();
setInterval(function() {
console.log('sent', sent, 'free', freemem(), 'cmdqlen', pub.command_queue.length, 'offqlen', pub.offline_queue.length);
}, 1000);