我正在使用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);
process1
,process2
,process3
,从事件流库实现为.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()
答案 0 :(得分:0)
为事件使用error
以外的名称:
self.emit('error', err);
可以说:
self.emit('err', err);
不会触发.pipe
安装的监听器。
然后使用:.on('err', console.log)
这可能比尝试更改.pipe
更好,因此它不会对error
执行任何操作。