0

我在 Amazon S3 的 NodeJS 模块中遇到以下错误:Knox

events.js:72
        throw er; // Unhandled 'error' event
              ^
Error: socket hang up
    at SecurePair.error (tls.js:934:23)
    at CleartextStream.read [as _read] (tls.js:432:17)
    at CleartextStream.Readable.read (_stream_readable.js:320:10)
    at EncryptedStream.write [as _write] (tls.js:345:25)
    at doWrite (_stream_writable.js:219:10)
    at writeOrBuffer (_stream_writable.js:209:5)
    at EncryptedStream.Writable.write (_stream_writable.js:180:11)
    at write (_stream_readable.js:573:24)
    at flow (_stream_readable.js:582:7)
    at Socket.pipeOnReadable (_stream_readable.js:614:5)
    at Socket.EventEmitter.emit (events.js:92:17)

启用后longjohn,我可以说错误是在从 Amazon S3 显示图像的路径上。

exports.image = function(req, res) {
    var type = req.params.type;
    var id = req.params.id;
    var file = req.params.file;
    var url = '/' + type + '/' + id + '/' + file;


    var data = '';
    knoxClient.get(url).on('response', function(s3res) {
        s3res.setEncoding('binary');
        s3res.on('data', function(chunk){
            data += chunk;
        });
        s3res.on('end', function() {
            res.write(data, encoding='binary');
            res.end();
        });
    }).end();
};

如何处理错误以使服务器不会崩溃?

4

1 回答 1

0

您很可能忘记为'error'服务器套接字的事件添加处理程序。

堆栈不包含对您的代码的任何引用的原因是由于 node.js 的事件性质。每当事件触发时,堆栈都会从头开始重新启动。因此,调试异步调用有点困难。

您可以在开发过程中尝试使用longjohn

于 2013-09-30T08:12:04.313 回答