I am getting the following error:
events.js:48
throw arguments[1]; // Unhandled 'error' event
^
Error: socket hang up
at createHangUpError (http.js:1091:15)
at Socket.onend (http.js:1154:27)
at TCP.onread (net.js:363:26)
In node v0.6.6, my code has multiple http.request and .get calls. Please suggest ways to track what causes the socket hang up, and on which request/call it is. Thank you
Additionally, you can set the
NODE_DEBUG
environment variable tonet
to get information about what all the sockets are doing. This way you can isolate which remote resource is resetting the connection.Quick and dirty solution for development:
Use longjohn, you get long stack traces that will contain the async operations.
Clean and correct solution: Technically, in node, whenever you emit an
'error'
event and no one listens to it, it will throw. To make it not throw, put a listener on it and handle it yourself. That way you can log the error with more information.To have one listener for a group of calls you can use domains and also catch other errors on runtime. Make sure each async operation related to http(Server/Client) is in different domain context comparing to the other parts of the code, the domain will automatically listen to the(Domains are depreceated).error
events and will propagate it to it's own handler. So you only listen to that handler and get the error data. You also get more information for free.As
Mike
suggested you can also setNODE_DEBUG=net
or use strace. They both provide you what is node doing internally.Most probably your server socket connection was somehow closed before all http.ServerResponse objects have ended. Make sure that you have stopped all incoming requests before doing something with incoming connections (incomming connection is something different than incoming HTTP request).
In addition to ftft1885's answer
When I had this "socket hang up" error, it was because I wasn't catching the requests errors.
use