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?
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)
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:
The browser, curl, everything else connects just fine. Yet, sure enough, changing the binding address to be:
And nodejs' using xmlrpc connects just fine. This occurred on a Mac OS X 10.9.1. Very odd.
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 oflocalhost
, and thenode
client started working.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.
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).