如何跟踪节点网络代码中的错误?

时间:2019-01-17 18:15:50

标签: node.js debugging https

我正试图找出为什么我的代码因此错误而失败:

 { Error: connect ECONNREFUSED 127.0.0.1:443
     at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1082:14)
   errno: 'ECONNREFUSED',
   code: 'ECONNREFUSED',
   syscall: 'connect',
   address: '127.0.0.1',
   port: 443 }

,该错误的堆栈跟踪如下所示:

 Error: connect ECONNREFUSED 127.0.0.1:443
     at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1082:14)

我正在建立网络连接,但是我没有尝试连接到本地主机。

我正在使用的网络代码在其他情况下也可以正常工作(并连接到正确的主机)。

我使用的是brew install提供的节点11.6.0,看来在brew“ Cellar”目录结构中唯一出现的字符串“ net.js”是在节点二进制文件本身中。换句话说,即使在

之后
 brew install --build-from-source node

运行

 find /usr/local/Cellar/node/11.6.0 -type f | xargs fgrep -l net.js

仅找到一个文件:/usr/local/Cellar/node/11.6.0/bin/node并且该目录树中没有net。*文件。

如果有关系,我的似乎触发此错误的代码如下:

  const get_json_with_auth= async (channel, url) => {
    const parsed_url= URL.parse(url);
   return new Promise((good, fail) => {
     let request= require('https').get({
       hostname: parsed_url.hostname,
       path: parsed_url.path,
       headers: {
         Authorization: get_auth('GET', channel, url)
       }
     });
     console.log('url', url);
     request.on('response', response=> {
       const chunks= [];
       response.on('data', data=> chunks.push(data));
       response.on('end', ()=> good(JSON.parse(Buffer.concat(chunks).toString())));
     });
     request.on('error', err=> fail(err));
   });
 };

(我在OSX高山脉上。)

但是,再次,我使用的url中的主机名不能解析为localhost(在其他情况下也可以正常工作)。

如何隔离这样的问题?

1 个答案:

答案 0 :(得分:0)

使用环境变量NODE_DEBUG ='net,tls,http,https'运行我的代码可以给我足够的信息来识别(并隔离)问题。