写入流发出错误后恢复流程?

时间:2014-06-15 16:26:57

标签: node.js

我正在使用nodejs流作为数据处理的管道。我正在遇到的问题是,只要我的writeStream目标发出错误,管道就会停止将数据流向writeStream。实际上,看起来pipe就是这样实现的。一旦发出单个错误,writeStream就会从管道中分离出来。 https://github.com/joyent/node/blob/master/lib/stream.js#L89-112

这似乎对我想要的东西有点激进。我希望能够记下错误,但保持管道运行。我怎么能这样做?

我的信息流看起来像这样:

client.readStream()
        .pipe(process1)
        .pipe(process2)
        .pipe(process3)
        .pipe(mongo.writeStream())
        .on('data', console.log)
        .on('error', console.log);

process1process2process3,从事件流库实现为.map()。

mongo写入流看起来像这样。

function MongoStream(_mongo) {
  Stream.Writable.call(this, { objectMode : true });
}

util.inherits(MongoStream, Stream.Writable);

MongoStream.prototype._write = function (model, encoding, callback) {
  var self = this;
  console.log("Saving model");
  model.save(function(err, result) {
    if(err){ 
        self.emit('error', err);
    } else {
        console.log("model saved");
        self.emit('data', result);
    }
    callback();
  });
};

读取流只是来自猫鼬模型的.find().stream()

1 个答案:

答案 0 :(得分:0)

为事件使用error以外的名称:

self.emit('error', err);

可以说:

self.emit('err', err);

不会触发.pipe安装的监听器。

然后使用:.on('err', console.log)

这可能比尝试更改.pipe更好,因此它不会对error执行任何操作。