我正试图找出我的代码失败的原因,并出现以下错误:
{ 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)
我正在进行网络连接,但我没有尝试连接到localhost。
我使用的网络代码在其他情况下运行良好(并连接到正确的主机)。
我使用的是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/note/11.60/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(在其他上下文中也可以正常工作)。
如何隔离这样的问题?
使用环境变量NODE_DEBUG='net,tls,http,https'运行我的代码给了我足够的信息来识别(并隔离)问题。