0

我正在实现一个节点应用程序,它从 BigCommerce 中引入了订单详细信息。使用 Restify JsonClient 异步多次调用 BigCommerce API。

它适用于某些呼叫,但之后我给出错误: [Error: socket hang up] code: 'ECONNRESET', sslError: undefined, body: {}

我试过关闭套接字池,即通过设置agent=false,但它仍然给出同样的错误。

以下是调用 BigCommerce API 的代码

makeRequest = function (url, params, headers, orderDetails, cb) {
                var options = {
              headers: headers
              };

                var client = restify.createJsonClient({
                    url: url
                });

                client.get(options, function(err, req, res, obj) {
                    if(err){
                        console.log(err);
                        cb(err,obj);
                    } else if(obj != null) {
                        var result = obj;
                        if(orderDetails == null) {
                            cb(null,result);
                        } else {
                            cb(null, result , orderDetails);
                        }
                    }
                });
            };

我收到以下错误:

{ [Error: socket hang up] code: 'ECONNRESET', sslError: unde
fined, body: {} } Error: socket hang up
    at SecurePair.error (tls.js:993:23)
    at EncryptedStream.CryptoStream._done (tls.js:689:22)
    at CleartextStream.read [as _read] (tls.js:490:24)
    at CleartextStream.Readable.read (_stream_readable.js:320:10)
    at EncryptedStream.onCryptoStreamFinish (tls.js:301:47)
    at EncryptedStream.g (events.js:175:14)
    at EncryptedStream.EventEmitter.emit (events.js:117:20)
    at finishMaybe (_stream_writable.js:352:12)
    at endWritable (_stream_writable.js:359:3)
    at EncryptedStream.Writable.end (_stream_writable.js:337:5)
    at EncryptedStream.CryptoStream.end (tls.js:628:31)
    at Socket.onend (_stream_readable.js:483:10) 

为什么我会收到这样的错误?我该如何处理?

谢谢

4

2 回答 2

1

我只是想确保您在正确的区域设置代理设置。

包括

“代理”:假

在您的选择中。(您粘贴的代码中的选项中没有设置)

每 gfpacheco 在此处的评论中:https ://github.com/restify/node-restify/issues/485

默认情况下,NodeJS 使用代理来保持 TCP 连接打开,因此您可以重用它。问题是,如果服务器已关闭,或者无论出于何种原因关闭您的连接,您都会收到 ECONNRESET 错误。

每次只需要在客户端创建中设置 agent: false 就关闭连接

我已经尝试过这个解决方案,它对我有用。

除此之外,

“secureOptions”:“constants.SSL_OP_NO_TLSv1_2”

此处发布的解决方案听起来可能是正确的路径,因为您收到了sslError

于 2016-04-21T14:58:49.117 回答
0

也许您遇到了这个问题https://github.com/joyent/node/issues/5360

TL;DR:您可以尝试使用最新的节点版本并secureOptions: constants.SSL_OP_NO_TLSv1_2添加到您的选项中。

于 2014-03-24T13:07:42.647 回答