ECONNREFUSED error with node.js that does not occu

2020-02-27 03:02发布

问题:

I'm making an http request with the node.js client, and I get an ECONNREFUSED error. When I make what appears to be the same request with my browser or curl(1), it works just fine

Here's the node request:

var options = {
  host: 'localhost',
  port: 8080,
  path: '/explorers/1.0/agegroup',
  method: 'GET'
};

var req = http.request(options, function(res) {
  res.setEncoding('utf8');
  res.on('data', function (chunk) {
    console.log('BODY: ' + chunk);
  });
});

req.on('error', function(e) {
  console.log(e);
});

req.end();

And it gives me the error:

{ [Error: connect ECONNREFUSED]
  code: 'ECONNREFUSED',
  errno: 'ECONNREFUSED',
  syscall: 'connect' }

But when I make the same request with a different client (curl in this case):

$ curl http://localhost:8080/explorers/1.0/agegroup
{... response JSON ...}

Other notes:

  • I've tried changing the host to www.google.com and the port to 80, and node makes the connection successfully

  • I've tried changing the port of the server, and I can still make requests with all clients but node.js (which still gets ECONNREFUSED)

  • The server to which I'm connecting is the CherryPy WSGI Server. When I try connecting to a node server at localhost:8080, it works fine, which would make me think it's the server's problem, except other clients work with the CherryPy server.

  • I've tried using the same headers that my browser is using, but that doesn't work, and it seems like the problem is at the TCP level anyway, so HTTP headers shouldn't be an issue.

What's wrong with my node request?

回答1:

I disagree with Soman's disagreement.

I've been pulling my hair out on this one, but yes, sure enough nodejs v0.10.24 and v0.10.25 refuse to connect to a PHP 5.4 development server (PHP's command line server) when invoked as:

php -S localhost:8088

The browser, curl, everything else connects just fine. Yet, sure enough, changing the binding address to be:

php -S 127.0.0.1:8088 

And nodejs' using xmlrpc connects just fine. This occurred on a Mac OS X 10.9.1. Very odd.



回答2:

I guess sometimes you just need to step away from the problem...

I found a solution, but it doesn't seem to answer the question, and I don't really like the it.

I changed the CherryPy server configuration to serve at 127.0.0.1 instead of localhost, and the node client started working.



回答3:

I just faced the same problem.

Note that Windows 7 by default doesn't include an entry for localhost in C:\Windows\System32\drivers\etc\hosts (wikipedia reference)

Adding the entry for localhost has no effect with Node.js (0.10.25) as it apparently skips the hosts file completely.

Use 127.0.0.1 as local address instead, this will works what ever is in your hosts file.



回答4:

I had the same problem. I was able to resolve it by replacing the localhost or 127.0.0.1 by my system's ip address(use ifconfig for the ip address).



回答5:

I exactly faced the same issue where I was accessing a third party url. I tried using dns (subdomain.domain.com) and ip (XXX.XXX.XXX.XXX) both but it did not work.

After some struggle, later I realized that this was a problem at server (subdomain.domain.com) end which was not responsive and gone down.

I disagree this is a problem with localhost / 127.0.0.1 (or domain name vs IP address). ( In above case, it's surely a case of incorrect host mapping)



标签: http node.js